Inputs and Action sequences! Or, how you can pass an argument into your snippet.

  • 3
  • Article
  • Updated 3 months ago
A request was made a while back to be able to pass custom arguments to a Javascript snippet. We reported that this was possible in Millau, but the approach hasn't been clear. So, I wanted to show how this can be done in the action framework, thanks to inputs. But first, I have to come clean. If you're looking for the way to pass arguments to a snippet, now that I've lured you here, I wanted to ask you to consider whether you need code to accomplish your goal. At the bottom of this post is XML for a simple page that shows 4 ways inputs can be used (one of which is a way you can pass arguments to snippets). 

What are inputs? Take a look at our documentation:
https://docs.skuid.com/latest/en/skuid/action-framework/action-sequences/#inputs
"Inputs provide the flexibility to have different properties in each instance of a reusable action sequence. With properly configured inputs, a general set of actions can be configured into a sequence. Then each time the action sequence is called, the various inputs it requires to run can be set at each instance, allowing for incredibly flexible, reusable action sequences."

Inputs can have 4 types, which determines where the input property can be used within various action types.

Here are the types:
Value: For use within any arbitrary value properties.
Model: For use within any model properties.
Model Field: (Requires a Model type input) For use within any model field properties.
Model Condition: (Requires a Model type input) For use within any model condition properties.

How this applies to snippets:
We can set up an action sequence, and include whatever inputs we need. Then, we can call up the snippet from inside the action sequence, and it will be able to see the input values. In other words, the value of an action sequence's inputs are passed into the arguments of any snippets in the action sequence.

In my example page below, I've set up an action sequence named "Button * clicked."" It's got an input called "button," with a type of "Value." That value is passed into a snippet that the action sequence is running, with the following code:

var button = arguments[0].$Input.button,
$ = skuid.$;
console.log(button + " was pressed.");

All I'm doing is sending it to a console log, (boring!) but this can allow you to take multiple inputs and use them in your snippets. And, those input values will be different every time the action sequence is called, depending on what values are passed into those inputs. 

But before you go use this in your page to write more code, please take some time to look through the other ways I've used inputs in this page. By using action sequences, inputs, events, and branching logic (possible with branch actions) you can declaratively tackle many use cases that would have required code in the past. And, by using these declarative tools, others can more easily understand what you've built down the road, and it's easier to expand on what you've built. Finally, if you do ultimately need to fall back on a little code, inputs give you easier ways to tie into the declarative side.

One example of why this is useful is inside the "Inputs in Model Conditions" tab of the example page. I've set up a set of buttons that lets you filter contacts by the first letter of their last name. Instead of setting up 26 matching action sequences and connecting them to model conditions, I've got just one action sequence, with an input that I can very easily define in the button. This shows how inputs & action sequences can help with scalability. If we voted to add a 27th letter to the alphabet, all you (as the page owner) would need to do is add a new button that runs the same action sequence with new letter as the input. No new action sequence needed.



You can also pass one input into several model conditions, which I've set up in the tab called "One Input Used in Many Model Conditions." This example shows an account list, and each account has a row action called "See Details." That row action calls up the "Query Related Models" action sequence, and passes the Id of the chosen account into multiple models' conditions. With this, we're able to use one action and one input to query related Contacts, Opportunities, Cases, and Account History. Hopefully, this illustrates another way you can be efficient in building your pages; for example, if you needed to set up another related list in the future, this approach makes it easier to attach one additional model query to the action sequence. 

I definitely (and enthusiastically) recommend reviewing the documentation on inputs and action sequences, as well as the event framework. I think this approach could shrink your code footprint significantly.


<skuidpage unsavedchangeswarning="yes" personalizationmode="server" showsidebar="true" useviewportmeta="true" showheader="true" theme="Lightning Design">
    <models>
        <model id="UI" limit="20" query="true" createrowifnonefound="true" datasource="Ui-Only" processonclient="true">
            <fields>
                <field id="FirstLetter" displaytype="TEXT" label="FirstLetter"/>
            </fields>
            <conditions/>
            <actions/>
        </model>
        <model id="NewAccount" limit="1" query="false" createrowifnonefound="true" datasource="salesforce" sobject="Account">
            <fields>
                <field id="RecordTypeId"/>
                <field id="Name"/>
                <field id="Industry"/>
            </fields>
            <conditions/>
            <actions/>
        </model>
        <model id="ContactsList" limit="100" query="true" createrowifnonefound="false" datasource="salesforce" sobject="Contact">
            <fields>
                <field id="FirstName"/>
                <field id="LastName"/>
                <field id="AccountId"/>
                <field id="Account.Name"/>
            </fields>
            <conditions>
                <condition type="fieldvalue" value="" enclosevalueinquotes="true" field="LastName" operator="starts with" state="filterableoff" inactive="true" name="LastName" model="RelatedAccountHistory"/>
            </conditions>
            <actions/>
        </model>
        <model id="AccountList" limit="20" query="true" createrowifnonefound="false" datasource="salesforce" sobject="Account">
            <fields>
                <field id="RecordTypeId"/>
                <field id="Name"/>
                <field id="Id"/>
                <field id="Industry"/>
            </fields>
            <conditions/>
            <actions/>
        </model>
        <model id="RelatedOpportunities" limit="20" query="false" createrowifnonefound="false" datasource="salesforce" sobject="Opportunity">
            <fields>
                <field id="Amount"/>
                <field id="CloseDate"/>
                <field id="AccountId"/>
                <field id="Account.Name"/>
            </fields>
            <conditions>
                <condition type="fieldvalue" value="" enclosevalueinquotes="true" field="AccountId" fieldtargetobjects="Account" state="filterableoff" inactive="true" name="AccountId" model="RelatedAccountHistory"/>
            </conditions>
            <actions/>
        </model>
        <model id="RelatedContacts" limit="20" query="false" createrowifnonefound="false" datasource="salesforce" sobject="Contact">
            <fields>
                <field id="Name"/>
                <field id="AccountId"/>
                <field id="Account.Name"/>
                <field id="Email"/>
            </fields>
            <conditions>
                <condition type="fieldvalue" value="" enclosevalueinquotes="true" field="AccountId" fieldtargetobjects="Account" state="filterableoff" inactive="true" name="AccountId" model="RelatedAccountHistory"/>
            </conditions>
            <actions/>
        </model>
        <model id="RelatedCases" limit="20" query="false" createrowifnonefound="false" datasource="salesforce" sobject="Case">
            <fields>
                <field id="AccountId"/>
                <field id="Account.Name"/>
                <field id="Id"/>
                <field id="SuppliedName"/>
                <field id="Subject"/>
                <field id="Status"/>
            </fields>
            <conditions>
                <condition type="fieldvalue" value="" enclosevalueinquotes="true" field="AccountId" fieldtargetobjects="Account" state="filterableoff" inactive="true" name="AccountId" model="RelatedAccountHistory"/>
            </conditions>
            <actions/>
        </model>
        <model limit="20" query="false" createrowifnonefound="false" datasource="salesforce" sobject="AccountHistory" id="RelatedAccountHistory">
            <fields>
                <field id="AccountId"/>
                <field id="Account.Name"/>
                <field id="NewValue"/>
                <field id="OldValue"/>
                <field id="Field"/>
            </fields>
            <conditions>
                <condition type="fieldvalue" value="" enclosevalueinquotes="true" field="AccountId" fieldtargetobjects="Account" state="filterableoff" inactive="true" name="AccountId"/>
            </conditions>
            <actions/>
        </model>
    </models>
    <components>
        <tabset rememberlastusertab="true" defertabrendering="true" uniqueid="sk-ucX-235">
            <tabs>
                <tab name="Inputs in Model Conditions" loadlazypanels="true">
                    <components>
                        <wrapper uniqueid="sk-uks-2741">
                            <components>
                                <pagetitle model="UI" uniqueid="sk-uif-2120">
                                    <maintitle>Contact List - {{{FirstLetter}}} ({{$Model.ContactsList.data.length}})</maintitle>
                                    <actions/>
                                </pagetitle>
                            </components>
                            <styles>
                                <styleitem type="background"/>
                                <styleitem type="border" padding="all">
                                    <styles>
                                        <styleitem property="padding" value="16px"/>
                                        <styleitem property="box-sizing" value="border-box"/>
                                    </styles>
                                </styleitem>
                                <styleitem type="size"/>
                            </styles>
                        </wrapper>
                        <buttonset model="ContactsList" uniqueid="sk-ue--1158" position="center">
                            <buttons>
                                <button type="multi" label="A" uniqueid="sk-uf0-1163">
                                    <actions>
                                        <action type="action-sequence" action-sequence-id="fb5a4245-1085-494e-903d-a32a4ad90a44">
                                            <inputs>
                                                <input name="FirstLetter" value="A"/>
                                            </inputs>
                                        </action>
                                    </actions>
                                </button>
                                <button type="multi" label="B" uniqueid="sk-uf0-1167">
                                    <actions>
                                        <action type="action-sequence" action-sequence-id="fb5a4245-1085-494e-903d-a32a4ad90a44">
                                            <inputs>
                                                <input name="FirstLetter" value="B"/>
                                            </inputs>
                                        </action>
                                    </actions>
                                </button>
                                <button type="multi" label="C" uniqueid="sk-uf1-1171">
                                    <actions>
                                        <action type="action-sequence" action-sequence-id="fb5a4245-1085-494e-903d-a32a4ad90a44">
                                            <inputs>
                                                <input name="FirstLetter" value="C"/>
                                            </inputs>
                                        </action>
                                    </actions>
                                </button>
                                <button type="multi" label="D" uniqueid="sk-uf1-1175">
                                    <actions>
                                        <action type="action-sequence" action-sequence-id="fb5a4245-1085-494e-903d-a32a4ad90a44">
                                            <inputs>
                                                <input name="FirstLetter" value="D"/>
                                            </inputs>
                                        </action>
                                    </actions>
                                </button>
                                <button type="multi" label="E" uniqueid="sk-uf1-1179">
                                    <actions>
                                        <action type="action-sequence" action-sequence-id="fb5a4245-1085-494e-903d-a32a4ad90a44">
                                            <inputs>
                                                <input name="FirstLetter" value="E"/>
                                            </inputs>
                                        </action>
                                    </actions>
                                </button>
                                <button type="multi" label="F" uniqueid="sk-uf1-1183">
                                    <actions>
                                        <action type="action-sequence" action-sequence-id="fb5a4245-1085-494e-903d-a32a4ad90a44">
                                            <inputs>
                                                <input name="FirstLetter" value="F"/>
                                            </inputs>
                                        </action>
                                    </actions>
                                </button>
                                <button type="multi" label="G" uniqueid="sk-uf1-1187">
                                    <actions>
                                        <action type="action-sequence" action-sequence-id="fb5a4245-1085-494e-903d-a32a4ad90a44">
                                            <inputs>
                                                <input name="FirstLetter" value="G"/>
                                            </inputs>
                                        </action>
                                    </actions>
                                </button>
                                <button type="multi" label="H" uniqueid="sk-uf1-1191">
                                    <actions>
                                        <action type="action-sequence" action-sequence-id="fb5a4245-1085-494e-903d-a32a4ad90a44">
                                            <inputs>
                                                <input name="FirstLetter" value="H"/>
                                            </inputs>
                                        </action>
                                    </actions>
                                </button>
                                <button type="multi" label="I" uniqueid="sk-uf1-1195">
                                    <actions>
                                        <action type="action-sequence" action-sequence-id="fb5a4245-1085-494e-903d-a32a4ad90a44">
                                            <inputs>
                                                <input name="FirstLetter" value="I"/>
                                            </inputs>
                                        </action>
                                    </actions>
                                </button>
                                <button type="multi" label="J" uniqueid="sk-uf1-1199">
                                    <actions>
                                        <action type="action-sequence" action-sequence-id="fb5a4245-1085-494e-903d-a32a4ad90a44">
                                            <inputs>
                                                <input name="FirstLetter" value="J"/>
                                            </inputs>
                                        </action>
                                    </actions>
                                </button>
                                <button type="multi" label="K" uniqueid="sk-uga-1319">
                                    <actions>
                                        <action type="action-sequence" action-sequence-id="fb5a4245-1085-494e-903d-a32a4ad90a44">
                                            <inputs>
                                                <input name="FirstLetter" value="K"/>
                                            </inputs>
                                        </action>
                                    </actions>
                                </button>
                                <button type="multi" label="L" uniqueid="sk-ugb-1323">
                                    <actions>
                                        <action type="action-sequence" action-sequence-id="fb5a4245-1085-494e-903d-a32a4ad90a44">
                                            <inputs>
                                                <input name="FirstLetter" value="L"/>
                                            </inputs>
                                        </action>
                                    </actions>
                                </button>
                                <button type="multi" label="M" uniqueid="sk-ugb-1327">
                                    <actions>
                                        <action type="action-sequence" action-sequence-id="fb5a4245-1085-494e-903d-a32a4ad90a44">
                                            <inputs>
                                                <input name="FirstLetter" value="M"/>
                                            </inputs>
                                        </action>
                                    </actions>
                                </button>
                                <button type="multi" label="N" uniqueid="sk-ugb-1331">
                                    <actions>
                                        <action type="action-sequence" action-sequence-id="fb5a4245-1085-494e-903d-a32a4ad90a44">
                                            <inputs>
                                                <input name="FirstLetter" value="N"/>
                                            </inputs>
                                        </action>
                                    </actions>
                                </button>
                                <button type="multi" label="O" uniqueid="sk-ugb-1335">
                                    <actions>
                                        <action type="action-sequence" action-sequence-id="fb5a4245-1085-494e-903d-a32a4ad90a44">
                                            <inputs>
                                                <input name="FirstLetter" value="O"/>
                                            </inputs>
                                        </action>
                                    </actions>
                                </button>
                                <button type="multi" label="P" uniqueid="sk-ugb-1339">
                                    <actions>
                                        <action type="action-sequence" action-sequence-id="fb5a4245-1085-494e-903d-a32a4ad90a44">
                                            <inputs>
                                                <input name="FirstLetter" value="P"/>
                                            </inputs>
                                        </action>
                                    </actions>
                                </button>
                                <button type="multi" label="Q" uniqueid="sk-ugb-1343">
                                    <actions>
                                        <action type="action-sequence" action-sequence-id="fb5a4245-1085-494e-903d-a32a4ad90a44">
                                            <inputs>
                                                <input name="FirstLetter" value="Q"/>
                                            </inputs>
                                        </action>
                                    </actions>
                                </button>
                                <button type="multi" label="R" uniqueid="sk-ugb-1347">
                                    <actions>
                                        <action type="action-sequence" action-sequence-id="fb5a4245-1085-494e-903d-a32a4ad90a44">
                                            <inputs>
                                                <input name="FirstLetter" value="R"/>
                                            </inputs>
                                        </action>
                                    </actions>
                                </button>
                                <button type="multi" label="S" uniqueid="sk-ugb-1351">
                                    <actions>
                                        <action type="action-sequence" action-sequence-id="fb5a4245-1085-494e-903d-a32a4ad90a44">
                                            <inputs>
                                                <input name="FirstLetter" value="S"/>
                                            </inputs>
                                        </action>
                                    </actions>
                                </button>
                                <button type="multi" label="T" uniqueid="sk-ugb-1355">
                                    <actions>
                                        <action type="action-sequence" action-sequence-id="fb5a4245-1085-494e-903d-a32a4ad90a44">
                                            <inputs>
                                                <input name="FirstLetter" value="T"/>
                                            </inputs>
                                        </action>
                                    </actions>
                                </button>
                                <button type="multi" label="U" uniqueid="sk-ugb-1359">
                                    <actions>
                                        <action type="action-sequence" action-sequence-id="fb5a4245-1085-494e-903d-a32a4ad90a44">
                                            <inputs>
                                                <input name="FirstLetter" value="U"/>
                                            </inputs>
                                        </action>
                                    </actions>
                                </button>
                                <button type="multi" label="V" uniqueid="sk-ugb-1363">
                                    <actions>
                                        <action type="action-sequence" action-sequence-id="fb5a4245-1085-494e-903d-a32a4ad90a44">
                                            <inputs>
                                                <input name="FirstLetter" value="V"/>
                                            </inputs>
                                        </action>
                                    </actions>
                                </button>
                                <button type="multi" label="W" uniqueid="sk-ugb-1367">
                                    <actions>
                                        <action type="action-sequence" action-sequence-id="fb5a4245-1085-494e-903d-a32a4ad90a44">
                                            <inputs>
                                                <input name="FirstLetter" value="W"/>
                                            </inputs>
                                        </action>
                                    </actions>
                                </button>
                                <button type="multi" label="X" uniqueid="sk-ugb-1371">
                                    <actions>
                                        <action type="action-sequence" action-sequence-id="fb5a4245-1085-494e-903d-a32a4ad90a44">
                                            <inputs>
                                                <input name="FirstLetter" value="X"/>
                                            </inputs>
                                        </action>
                                    </actions>
                                </button>
                                <button type="multi" label="Y" uniqueid="sk-ugb-1375">
                                    <actions>
                                        <action type="action-sequence" action-sequence-id="fb5a4245-1085-494e-903d-a32a4ad90a44">
                                            <inputs>
                                                <input name="FirstLetter" value="Y"/>
                                            </inputs>
                                        </action>
                                    </actions>
                                </button>
                                <button type="multi" label="Z" uniqueid="sk-ugo-1427">
                                    <actions>
                                        <action type="action-sequence" action-sequence-id="fb5a4245-1085-494e-903d-a32a4ad90a44">
                                            <inputs>
                                                <input name="FirstLetter" value="Z"/>
                                            </inputs>
                                        </action>
                                    </actions>
                                </button>
                                <button type="multi" label="[All]" uniqueid="sk-uk9-2636">
                                    <actions>
                                        <action type="action-sequence" action-sequence-id="fb5a4245-1085-494e-903d-a32a4ad90a44"/>
                                    </actions>
                                </button>
                            </buttons>
                        </buttonset>
                        <skootable showconditions="true" showsavecancel="true" showerrorsinline="true" searchmethod="server" searchbox="true" showexportbuttons="false" hideheader="false" hidefooter="false" pagesize="10" alwaysresetpagination="false" createrecords="true" model="ContactsList" buttonposition="" mode="read" allowcolumnreordering="true" responsive="true" uniqueid="sk-uex-1107">
                            <fields>
                                <field id="FirstName" uniqueid="fi-uex-1108"/>
                                <field id="LastName" uniqueid="fi-uex-1109"/>
                                <field id="Account.Name" uniqueid="fi-uex-1111"/>
                            </fields>
                            <rowactions>
                                <action type="edit"/>
                                <action type="delete"/>
                            </rowactions>
                            <massactions usefirstitemasdefault="true">
                                <action type="massupdate"/>
                                <action type="massdelete"/>
                            </massactions>
                            <views>
                                <view type="standard"/>
                            </views>
                        </skootable>
                    </components>
                </tab>
                <tab name="One Input Used in Many Model Conditions" loadlazypanels="true">
                    <components>
                        <wrapper uniqueid="sk-uwb-1724">
                            <components>
                                <grid uniqueid="sk-uxF-1937">
                                    <divisions>
                                        <division behavior="flex" minwidth="100px" ratio="1">
                                            <components>
                                                <pagetitle model="AccountList" uniqueid="sk-ux0-1880">
                                                    <maintitle>Accounts List</maintitle>
                                                    <actions/>
                                                </pagetitle>
                                            </components>
                                        </division>
                                        <division behavior="fit" verticalalign="top">
                                            <components>
                                                <richtext multiple="false" uniqueid="sk-uxI-1961">
                                                    <contents>&lt;p&gt;[show/hide]&lt;/p&gt;
</contents>
                                                </richtext>
                                            </components>
                                        </division>
                                    </divisions>
                                    <styles>
                                        <styleitem type="background" bgtype="none"/>
                                    </styles>
                                </grid>
                                <wrapper uniqueid="sk-uwb-1736">
                                    <components>
                                        <skootable showconditions="true" showsavecancel="true" showerrorsinline="true" searchmethod="server" searchbox="true" showexportbuttons="false" hideheader="false" hidefooter="false" pagesize="10" alwaysresetpagination="false" createrecords="true" model="AccountList" buttonposition="" mode="read" allowcolumnreordering="true" responsive="true" uniqueid="sk-umN-3245">
                                            <fields>
                                                <field id="Name" uniqueid="fi-umN-3247"/>
                                                <field id="Industry" hideable="true" uniqueid="fi-utp-975"/>
                                            </fields>
                                            <rowactions>
                                                <action type="edit"/>
                                                <action type="delete"/>
                                                <action type="multi" label="See Details" icon="sk-icon-account-profile">
                                                    <actions>
                                                        <action type="toggleRenderComponent" behavior="hide" componentid="sk-uwb-1736"/>
                                                        <action type="action-sequence" action-sequence-id="f2a4b89b-1e6d-46d5-a332-6f94f05720c1">
                                                            <inputs>
                                                                <input name="AccountId" value="{{Id}}"/>
                                                            </inputs>
                                                        </action>
                                                    </actions>
                                                </action>
                                            </rowactions>
                                            <massactions usefirstitemasdefault="true">
                                                <action type="massupdate"/>
                                                <action type="massdelete"/>
                                            </massactions>
                                            <views>
                                                <view type="standard"/>
                                            </views>
                                        </skootable>
                                    </components>
                                    <styles>
                                        <styleitem type="background"/>
                                        <styleitem type="border"/>
                                        <styleitem type="size"/>
                                    </styles>
                                </wrapper>
                            </components>
                            <styles>
                                <styleitem type="background" bgtype="color">
                                    <styles>
                                        <styleitem property="background-color" value="#bfbfbf"/>
                                    </styles>
                                </styleitem>
                                <styleitem type="border" padding="all">
                                    <styles>
                                        <styleitem property="padding" value="8px"/>
                                        <styleitem property="box-sizing" value="border-box"/>
                                    </styles>
                                </styleitem>
                                <styleitem type="size"/>
                            </styles>
                            <interactions>
                                <interaction type="tap">
                                    <action type="toggleRenderComponent" behavior="toggle" componentid="sk-uwb-1736"/>
                                </interaction>
                            </interactions>
                        </wrapper>
                        <wrapper uniqueid="sk-ums-3712">
                            <components>
                                <wrapper uniqueid="sk-2eqK-673">
                                    <components>
                                        <pagetitle uniqueid="sk-2epx-632" model="RelatedOpportunities">
                                            <actions/>
                                            <maintitle>{{Account.Name}}</maintitle>
                                        </pagetitle>
                                        <skootable showconditions="true" showsavecancel="true" showerrorsinline="true" searchmethod="server" searchbox="true" showexportbuttons="false" hideheader="false" hidefooter="false" pagesize="10" alwaysresetpagination="false" createrecords="true" model="RelatedOpportunities" buttonposition="" mode="read" allowcolumnreordering="true" responsive="true" uniqueid="sk-umU-3394" heading="Related Opportunities">
                                            <fields>
                                                <field id="Amount" uniqueid="fi-umU-3395"/>
                                                <field id="CloseDate" uniqueid="fi-umU-3396"/>
                                                <field id="AccountId" uniqueid="fi-umU-3397"/>
                                                <field id="Account.Name" uniqueid="fi-umU-3398"/>
                                            </fields>
                                            <rowactions>
                                                <action type="edit"/>
                                                <action type="delete"/>
                                            </rowactions>
                                            <massactions usefirstitemasdefault="true">
                                                <action type="massupdate"/>
                                                <action type="massdelete"/>
                                            </massactions>
                                            <views>
                                                <view type="standard"/>
                                            </views>
                                        </skootable>
                                    </components>
                                    <styles>
                                        <styleitem type="background"/>
                                        <styleitem type="border"/>
                                        <styleitem type="size"/>
                                    </styles>
                                    <renderconditions logictype="and">
                                        <rendercondition type="fieldvalue" enclosevalueinquotes="true" fieldmodel="RelatedOpportunities" sourcetype="modelproperty" nosourcerowbehavior="deactivate" sourceproperty="hasRows"/>
                                    </renderconditions>
                                </wrapper>
                                <wrapper uniqueid="sk-2eqP-715">
                                    <components>
                                        <pagetitle uniqueid="sk-2eqR-738" model="RelatedContacts">
                                            <maintitle>{{Account.Name}}</maintitle>
                                            <actions/>
                                        </pagetitle>
                                        <skootable showconditions="true" showsavecancel="true" showerrorsinline="true" searchmethod="server" searchbox="true" showexportbuttons="false" hideheader="false" hidefooter="false" pagesize="10" alwaysresetpagination="false" createrecords="true" model="RelatedContacts" buttonposition="" mode="read" allowcolumnreordering="true" responsive="true" uniqueid="sk-umm-3642" heading="Related Contacts">
                                            <fields>
                                                <field id="Name" uniqueid="fi-umm-3643"/>
                                                <field id="AccountId" uniqueid="fi-umm-3644"/>
                                                <field id="Account.Name" uniqueid="fi-umm-3645"/>
                                                <field id="Email" uniqueid="fi-umm-3646"/>
                                            </fields>
                                            <rowactions>
                                                <action type="edit"/>
                                                <action type="delete"/>
                                            </rowactions>
                                            <massactions usefirstitemasdefault="true">
                                                <action type="massupdate"/>
                                                <action type="massdelete"/>
                                            </massactions>
                                            <views>
                                                <view type="standard"/>
                                            </views>
                                        </skootable>
                                    </components>
                                    <styles>
                                        <styleitem type="background"/>
                                        <styleitem type="border"/>
                                        <styleitem type="size"/>
                                    </styles>
                                    <renderconditions logictype="and">
                                        <rendercondition type="fieldvalue" enclosevalueinquotes="true" fieldmodel="RelatedContacts" sourcetype="modelproperty" nosourcerowbehavior="deactivate" sourceproperty="hasRows"/>
                                    </renderconditions>
                                </wrapper>
                                <wrapper uniqueid="sk-2eqZ-766">
                                    <components>
                                        <pagetitle uniqueid="sk-2eqd-809" model="RelatedCases">
                                            <maintitle>{{Account.Name}}</maintitle>
                                            <actions/>
                                        </pagetitle>
                                        <skootable showconditions="true" showsavecancel="true" showerrorsinline="true" searchmethod="server" searchbox="true" showexportbuttons="false" hideheader="false" hidefooter="false" pagesize="10" alwaysresetpagination="false" createrecords="true" model="RelatedCases" buttonposition="" mode="read" allowcolumnreordering="true" responsive="true" uniqueid="sk-unU-4088" heading="Related Cases">
                                            <fields>
                                                <field id="AccountId" uniqueid="fi-unU-4089"/>
                                                <field id="Account.Name" uniqueid="fi-unU-4090"/>
                                                <field id="Id" uniqueid="fi-unU-4091"/>
                                                <field id="SuppliedName" uniqueid="fi-unU-4092"/>
                                                <field id="Subject" uniqueid="fi-unU-4093"/>
                                                <field id="Status" uniqueid="fi-unU-4094"/>
                                            </fields>
                                            <rowactions>
                                                <action type="edit"/>
                                                <action type="delete"/>
                                            </rowactions>
                                            <massactions usefirstitemasdefault="true">
                                                <action type="massupdate"/>
                                                <action type="massdelete"/>
                                            </massactions>
                                            <views>
                                                <view type="standard"/>
                                            </views>
                                        </skootable>
                                    </components>
                                    <styles>
                                        <styleitem type="background"/>
                                        <styleitem type="border"/>
                                        <styleitem type="size"/>
                                    </styles>
                                    <renderconditions logictype="and">
                                        <rendercondition type="fieldvalue" enclosevalueinquotes="true" fieldmodel="RelatedCases" sourcetype="modelproperty" nosourcerowbehavior="deactivate" sourceproperty="hasRows"/>
                                    </renderconditions>
                                </wrapper>
                                <wrapper uniqueid="sk-2eqa-780">
                                    <components>
                                        <pagetitle uniqueid="sk-2eqg-817" model="RelatedAccountHistory">
                                            <maintitle>{{Account.Name}}</maintitle>
                                            <actions/>
                                        </pagetitle>
                                        <skootable showconditions="true" showsavecancel="false" showerrorsinline="true" searchmethod="server" searchbox="true" showexportbuttons="false" hideheader="false" hidefooter="false" pagesize="10" alwaysresetpagination="false" createrecords="false" model="RelatedAccountHistory" buttonposition="" mode="readonly" allowcolumnreordering="true" responsive="true" uniqueid="sk-upv-5073" heading="Account History">
                                            <fields>
                                                <field id="AccountId" uniqueid="fi-upv-5074"/>
                                                <field id="Account.Name" uniqueid="fi-upv-5075"/>
                                                <field id="NewValue" uniqueid="fi-upv-5076"/>
                                                <field id="OldValue" uniqueid="fi-upv-5077"/>
                                                <field id="Field" uniqueid="fi-upv-5078"/>
                                            </fields>
                                            <rowactions/>
                                            <massactions usefirstitemasdefault="true"/>
                                            <views>
                                                <view type="standard"/>
                                            </views>
                                        </skootable>
                                    </components>
                                    <styles>
                                        <styleitem type="background"/>
                                        <styleitem type="border"/>
                                        <styleitem type="size"/>
                                    </styles>
                                    <renderconditions logictype="and">
                                        <rendercondition type="fieldvalue" enclosevalueinquotes="true" fieldmodel="RelatedAccountHistory" sourcetype="modelproperty" nosourcerowbehavior="deactivate" sourceproperty="hasRows"/>
                                    </renderconditions>
                                </wrapper>
                            </components>
                            <styles>
                                <styleitem type="background" bgtype="color">
                                    <styles>
                                        <styleitem property="background-color" value="#c6d9f0"/>
                                    </styles>
                                </styleitem>
                                <styleitem type="border" padding="bottom,top,right,left,">
                                    <styles>
                                        <styleitem property="padding-left" value="64px"/>
                                        <styleitem property="padding-top" value="32px"/>
                                        <styleitem property="padding-right" value="64px"/>
                                        <styleitem property="padding-bottom" value="32px"/>
                                        <styleitem property="box-sizing" value="border-box"/>
                                    </styles>
                                </styleitem>
                                <styleitem type="size"/>
                            </styles>
                        </wrapper>
                    </components>
                </tab>
                <tab name="Inputs in Models" loadlazypanels="true">
                    <components>
                        <buttonset model="NewAccount" uniqueid="sk-ueB-925">
                            <buttons>
                                <button type="save" label="Save" uniqueid="sk-ueC-932" window="self" rollbackonanyerror="true"/>
                                <button type="cancel" label="Cancel" uniqueid="sk-ueG-950" window="self"/>
                            </buttons>
                        </buttonset>
                        <grid uniqueid="sk-udE-491" columngutter="32px" rowgutter="32px">
                            <divisions>
                                <division behavior="flex" minwidth="100px" ratio="1">
                                    <components>
                                        <basicfieldeditor showheader="true" showsavecancel="false" showerrorsinline="true" model="NewAccount" uniqueid="sk-ud5-454" mode="edit">
                                            <columns>
                                                <column width="100%" uniqueid="sk-ud5-450">
                                                    <sections>
                                                        <section title="Section A" uniqueid="sk-ud5-451" collapsible="no" showheader="false">
                                                            <fields>
                                                                <field uniqueid="sk-udB-484" id="Name"/>
                                                                <field uniqueid="sk-ud_-847" id="Industry" readonly="true"/>
                                                            </fields>
                                                        </section>
                                                    </sections>
                                                </column>
                                            </columns>
                                        </basicfieldeditor>
                                    </components>
                                </division>
                                <division behavior="flex" verticalalign="top" minwidth="100px" ratio="1">
                                    <components>
                                        <template multiple="false" uniqueid="sk-ue2-858" model="RelatedAccountHistory">
                                            <contents>Select an industry:</contents>
                                        </template>
                                        <buttonset model="NewAccount" uniqueid="sk-udI-529" position="left">
                                            <buttons>
                                                <button type="multi" label="Sprockets" uniqueid="sk-udK-535">
                                                    <actions>
                                                        <action type="action-sequence" action-sequence-id="bdd4b117-96c1-4f3f-95b9-966caf24b686">
                                                            <inputs>
                                                                <input name="Industry" value="Sprockets"/>
                                                            </inputs>
                                                        </action>
                                                    </actions>
                                                </button>
                                                <button type="multi" label="Widgets" uniqueid="sk-udK-539">
                                                    <actions>
                                                        <action type="action-sequence" action-sequence-id="bdd4b117-96c1-4f3f-95b9-966caf24b686">
                                                            <inputs>
                                                                <input name="Industry" value="Widgets"/>
                                                            </inputs>
                                                        </action>
                                                    </actions>
                                                </button>
                                                <button type="multi" label="Whosits" uniqueid="sk-udL-543">
                                                    <actions>
                                                        <action type="action-sequence" action-sequence-id="bdd4b117-96c1-4f3f-95b9-966caf24b686">
                                                            <inputs>
                                                                <input name="Industry" value="Whosits"/>
                                                            </inputs>
                                                        </action>
                                                    </actions>
                                                </button>
                                            </buttons>
                                        </buttonset>
                                    </components>
                                </division>
                            </divisions>
                            <styles>
                                <styleitem type="background" bgtype="none"/>
                            </styles>
                        </grid>
                    </components>
                </tab>
                <tab name="Inputs in Snippets">
                    <components>
                        <grid uniqueid="sk-uYB-322">
                            <divisions>
                                <division behavior="flex" verticalalign="top" minwidth="100px" ratio="1">
                                    <components/>
                                </division>
                                <division behavior="fit" verticalalign="top">
                                    <components>
                                        <template multiple="false" uniqueid="sk-uX--207" model="RelatedAccountHistory">
                                            <contents>Open the console, then click each button to the right.</contents>
                                        </template>
                                    </components>
                                </division>
                                <division behavior="fit" verticalalign="top">
                                    <components>
                                        <buttonset uniqueid="sk-uYB-317" model="RelatedAccountHistory">
                                            <buttons>
                                                <button type="multi" label="A" uniqueid="sk-uYG-442">
                                                    <actions>
                                                        <action type="action-sequence" action-sequence-id="1b0e367c-80f2-49d1-a1db-d805346a806f">
                                                            <inputs>
                                                                <input name="button" value="A"/>
                                                            </inputs>
                                                        </action>
                                                    </actions>
                                                </button>
                                                <button type="multi" label="B" uniqueid="sk-uYG-446">
                                                    <actions>
                                                        <action type="action-sequence" action-sequence-id="1b0e367c-80f2-49d1-a1db-d805346a806f">
                                                            <inputs>
                                                                <input name="button" value="B"/>
                                                            </inputs>
                                                        </action>
                                                    </actions>
                                                </button>
                                            </buttons>
                                        </buttonset>
                                    </components>
                                </division>
                                <division behavior="flex" verticalalign="top" minwidth="100px" ratio="1">
                                    <components/>
                                </division>
                            </divisions>
                            <styles>
                                <styleitem type="background" bgtype="none"/>
                            </styles>
                        </grid>
                    </components>
                </tab>
            </tabs>
        </tabset>
    </components>
    <resources>
        <labels/>
        <javascript>
            <jsitem location="inlinesnippet" name="buttonPressed" cachelocation="false">var button = arguments[0].$Input.button,
$ = skuid.$;
console.log(button + " was pressed.");</jsitem>
        </javascript>
        <css/>
        <actionsequences uniqueid="sk-ucn-436">
            <actionsequence id="1b0e367c-80f2-49d1-a1db-d805346a806f" label="Button * clicked" type="reusable" uniqueid="sk-ucn-437">
                <description/>
                <actions>
                    <action type="custom" snippet="buttonPressed"/>
                </actions>
                <inputs>
                    <input type="value" name="button"/>
                </inputs>
            </actionsequence>
            <actionsequence id="bdd4b117-96c1-4f3f-95b9-966caf24b686" label="Set Industry" type="reusable" uniqueid="sk-uej-1040">
                <description/>
                <actions>
                    <action type="updateRow" fieldmodel="NewAccount" affectedrows="context" field="Industry" enclosevalueinquotes="true" value="{{$Input.Industry}}"/>
                </actions>
                <inputs>
                    <input type="value" name="Industry"/>
                </inputs>
            </actionsequence>
            <actionsequence id="fb5a4245-1085-494e-903d-a32a4ad90a44" label="Name Starts With" type="reusable" uniqueid="sk-ui_-2206">
                <description/>
                <actions>
                    <action type="setCondition" model="ContactsList" condition="LastName" value="{{$Input.FirstLetter}}"/>
                    <action type="requeryModel" model="ContactsList" behavior="standard"/>
                    <action type="updateRow" fieldmodel="UI" affectedrows="context" field="FirstLetter" enclosevalueinquotes="true" value="{{$Input.FirstLetter}}"/>
                </actions>
                <inputs>
                    <input type="value" name="FirstLetter"/>
                </inputs>
            </actionsequence>
            <actionsequence id="f83f7440-9781-4e16-a9db-725576540350" label="SetConditions" type="reusable" uniqueid="sk-upZ-4985">
                <description>{{$Input.ConditionFieldValue}}</description>
                <actions>
                    <action type="setCondition" model="{{$Input.ModelToQuery}}" condition="{{$Input.ConditionToChange}}" value="{{$Input.AccountId}}"/>
                    <action type="requeryModel" model="{{$Input.ModelToQuery}}" behavior="standard"/>
                </actions>
                <inputs>
                    <input type="value" name="ConditionFieldValue"/>
                    <input type="model" name="ModelToQuery"/>
                    <input type="model-field" name="ConditionField" model-source="ModelToQuery"/>
                    <input type="model-condition" name="ConditionToChange" model-source="ModelToQuery"/>
                </inputs>
            </actionsequence>
            <actionsequence id="f2a4b89b-1e6d-46d5-a332-6f94f05720c1" label="Query Related Models" type="reusable" uniqueid="sk-um8-3139">
                <description/>
                <actions>
                    <action type="action-sequence" action-sequence-id="f83f7440-9781-4e16-a9db-725576540350" input-ConditionField="AccountId" fieldtargetobjects="Account">
                        <inputs>
                            <input name="ModelToQuery" value="RelatedOpportunities"/>
                            <input name="ConditionFieldValue" value="{{$Input.AccountId}}"/>
                            <input name="ConditionField" value="AccountId"/>
                            <input name="ConditionToChange" value="AccountId"/>
                        </inputs>
                    </action>
                    <action type="action-sequence" action-sequence-id="f83f7440-9781-4e16-a9db-725576540350" input-ConditionField="AccountId" fieldtargetobjects="Account">
                        <inputs>
                            <input name="ModelToQuery" value="RelatedContacts"/>
                            <input name="ConditionFieldValue" value="{{$Input.AccountId}}"/>
                            <input name="ConditionField" value="AccountId"/>
                            <input name="ConditionToChange" value="AccountId"/>
                        </inputs>
                    </action>
                    <action type="action-sequence" action-sequence-id="f83f7440-9781-4e16-a9db-725576540350" input-ConditionField="AccountId" fieldtargetobjects="Account">
                        <inputs>
                            <input name="ModelToQuery" value="RelatedCases"/>
                            <input name="ConditionFieldValue" value="{{$Input.AccountId}}"/>
                            <input name="ConditionField" value="AccountId"/>
                            <input name="ConditionToChange" value="AccountId"/>
                        </inputs>
                    </action>
                    <action type="action-sequence" action-sequence-id="f83f7440-9781-4e16-a9db-725576540350" input-ConditionField="AccountId" fieldtargetobjects="Account">
                        <inputs>
                            <input name="ModelToQuery" value="RelatedAccountHistory"/>
                            <input name="ConditionFieldValue" value="{{$Input.AccountId}}"/>
                            <input name="ConditionField" value="AccountId"/>
                            <input name="ConditionToChange" value="AccountId"/>
                        </inputs>
                    </action>
                </actions>
                <inputs>
                    <input type="value" name="AccountId"/>
                </inputs>
            </actionsequence>
        </actionsequences>
    </resources>
    <styles>
        <styleitem type="background" bgtype="none"/>
    </styles>
</skuidpage>
Photo of Mark DeSimone

Mark DeSimone, Official Rep

  • 11,680 Points 10k badge 2x thumb
  • Excited

Posted 3 months ago

  • 3
Photo of Josef Lagorio

Josef Lagorio

  • 3,116 Points 3k badge 2x thumb
Very cool!