You need to sign in to do that
Don't have an account?
Brian Kessler
Lightning Component Superbadge: What's Wrong with My New Boat Button?
Hi,
I'm currently working on the Lightning Component Framework Specialist Superbadge.
When I click "New", at least as I've interpretted the requirements, the "Friends with Boats" pages is behaving as expected, but Trailhead complains:
Have I misunderstood a requirement?
Here is my markup:
I'm currently working on the Lightning Component Framework Specialist Superbadge.
When I click "New", at least as I've interpretted the requirements, the "Friends with Boats" pages is behaving as expected, but Trailhead complains:
Challenge Not yet complete... here's what's wrong: The BoatSearchForm component's "New" button should launch the default boat record create page using logic in its controller.
Have I misunderstood a requirement?
Here is my markup:
<aura:component controller="BoatSearchFormAuraCtrl" > <aura:attribute access="private" name="boatList" type="BoatType__c[]" default="[]" /> <aura:attribute access="private" name="showNewButton" type="Boolean" default="false" /> <aura:attribute access="private" name="selectedBoat" type="BoatType__c" /> <aura:handler name="init" value="{!this}" action="{!c.doInit}" /> <h2 class="slds-page-header__title">Find a Boat</h2> <form> <lightning:layout horizontalAlign="center"> <lightning:select name="select" value="{!v.selectedBoat}"> <option value="">All Types</option> <aura:iteration items="{!v.boatList}" var="boat"> <option value="{!boat.Name}" text="{!boat.Name}"></option> </aura:iteration> </lightning:select> <lightning:button name="Search" label="Search" variant="brand" /> <aura:if isTrue="{!v.showNewButton}"> <lightning:button name="New" label="New" variant="neutral" onclick="{!c.createBoat}"/> </aura:if> </lightning:layout> </form> </aura:component>And here is my controller:
({ doInit : function(component, event, helper) { component.set('v.showNewButton', $A.get('e.force:createRecord')); helper.setBoatTypeList(component); }, createBoat : function(component) { var createRecordEvent = $A.get('e.force:createRecord'); createRecordEvent.setParams({ 'entityApiName' : 'BoatType__c', 'defaultFieldValues': { 'Name': component.get('v.selectedBoat') }, }); createRecordEvent.fire(); } })
Thanks for all the great input.
Great call on the Boat/Boat Type confusion.
Allow me to repay the favour by suggesting the use of JavaScript ES6 maps instead of a second handler:
Here is my present code:
Markup:
Controller:
Helper:
I'm still not passing yet as "Friends with Boats" is apparently both the right and wrong name for this Lightning application. :-/
... But I'll start a clean, new thread for that....
Maps are really useful for so many things... unfortunately, Lightning support for them is limited. For example, you can't iterate over them. :-(
But, yes, you can definitely use maps to reduce your need for SOQL statements.
Whether it conflicts with the instructions, I do wish they'd learn to test for results rather than implementation details. It pisses me off that they enforce bad practices.
Still... "Challenge Not yet complete... here's what's wrong: The BoatSearchForm component's "New" button doesn't launch the new boat page with the correct default field values using logic in its controller."
Thanks by the way for tackling the question arround how to hide the New button based on the context. Learnt something today. Attribute type could be a function reference ;-) Anyways - anybody in the clear on this Superbadge... help appreciated!
Jeroen
--> I put my code in helper functions, per best practice. That made the test to fail. Moving the code to the controller, it worked immediately.
Anyways Thanks Jeroen for your response
Solution please follow the below links where i have given all the steps:--
https://developer.salesforce.com/forums/ForumsMain?id=9060G0000005NG8QAM
I am stuck in challenge 2. Functionality is working as expected. But I get error as - Challenge Not yet complete... here's what's wrong:
The BoatSearch component should instantiate the BoatSearchForm and BoatSearchResults components.
Below is my BoatSearch component. Any lead is apprciated.
Thanks,
Manish.
I am able to pass Step 2 , it uses less code, here we are focusing on main component BoatSearchForm, so below is its component and controller
<aura:component implements="flexipage:availableForAllPageTypes" controller="BoatType" >
<aura:attribute name ="BoatType" type="BoatType__c[]" />
<aura:handler name="init" value="{!this}" action="{!c.doInit}" />
<aura:attribute name ="selectedBoat" type="BoatType__c" />
<aura:attribute name ="showNew" type="Boolean" />
<aura:attribute name ="BTselectedValue" type="String" />
<lightning:layout horizontalAlign= "center">
<lightning:select name="select" value="{!v.BTselectedValue}" >
<option value="">All Types</option>
<aura:iteration items="{!v.BoatType}" var="t">
<option value="{!t.Id}">{!t.Name}</option>
</aura:iteration>
</lightning:select>
<lightning:button variant="brand" label="Search" />
<aura:if isTrue="{!v.showNew}">
<lightning:button variant="Neutral" label="New" onclick="{!c.handleClickNew}" />
</aura:if>
</lightning:layout>
</aura:component>
controller:
({
doInit : function(component, event, helper) {
var isEnabled = $A.get("e.force:createRecord");
if(isEnabled){
component.set("v.showNew",true);
}
var action = component.get("c.getBoatNames");
action.setCallback(this, function(response){
if(response.getState() === "SUCCESS"){
component.set("v.BoatType",response.getReturnValue());
}
});
$A.enqueueAction(action);
},
handleClickNew : function(component, event, helper) {
var navEvt = $A.get("e.force:createRecord");
navEvt.setParams({"entityApiName":"Boat__c"});
if(component.get("v.BTselectedValue") != ""){
navEvt.setParams({"defaultFieldValues": {"BoatType__c": component.get("v.BTselectedValue")}});
}
navEvt.fire();
}
})
Any advices .. ... :)
Can some one please help me out with the below issue.