Direkt zum Hauptbereich

Opportunity Button zum Ändern des Record Types

Wie einfach klingt eigentlich die folgende Aufgabe?
Erstelle einen Button auf dem Opportunity Objekt. Der Button muss den Record Type der offenen Opportunity ändern.
Nach einer kurzen Überlegungspause musste ich zugeben, dass die Aufgabe alles Andere als trivial ist.
Dafür muss eine neue VisualForce Seite entwickelt werden, eine neue Apex Klasse. Nicht zu vergessen ist die Testabdeckung.
Ziemlich aufwendig...
Aber nicht mit JavaScript!
Mit dem angehängten Code lässt sich der Aufwand deutlich reduzieren.
Code kopieren, den Record Type Namen anpassen, Button einbinden - 10 Minuten Aufwand.

{!REQUIRESCRIPT("/soap/ajax/24.0/connection.js")}

var query = "select name, id from recordtype where name='Neue Opportunity'";
var recordtype_NewOpp = sforce.connection.query(query);
var records = recordtype_NewOpp.getArray("records");

try{
sforce.connection.sessionid = '{!GETSESSIONID()}';
var opp = new sforce.SObject("Opportunity");
opp.id='{!Opportunity.Id}';
opp.RecordTypeId =records[0].Id;
var result = sforce.connection.update([opp]);
}catch (ex){
alert(ex);
}

if(result[0].success=='false'){
alert(result[0].errors.message);
}else{
location.reload(true);
}


Kommentare

  1. Ich gehe dabei gerne einen zweistufigen Weg:
    ein Custom Button mit Javascript Remoting wie oben, allerdings verkürzt um nur eine Checkbox zu setzen.

    Dazu ein Workflow, der abhängig von der Checkbox den RecordType setzt.

    Etwas mehr Aufwand, etwas leichteres Handling,

    Hier mein Button Code:

    // custom button to set a field!

    {!REQUIRESCRIPT("/soap/ajax/24.0/connection.js")}

    var myOpportunity = new sforce.SObject("Opportunity");
    myOpportunity.id = "{!myOpportunity.Id}";

    //alert(myOpportunity.id);

    myOpportunity.myflag__c = "true";

    var result = sforce.connection.update([myOpportunity]);

    if (result[0].getBoolean("success"))
    {
    // Refresh window
    window.location.reload();
    }
    else
    {
    alert("Error saving Trial");
    }

    AntwortenLöschen

Kommentar veröffentlichen

Beliebte Posts aus diesem Blog

Salesforce APEX Techniken

Mal auf die Schnelle zusammenbasteln „Das kann doch nicht so schwer sein!“ Das ist vermutlich einer der berühmtesten Sätze, mit dem ein (Salesforce) Entwickler konfrontiert wird.  Diese Aussage wird vor allem als Waffe benutzt, um den vom Entwickler geschätzten Aufwand und die damit verbundenen Kosten zu reduzieren. Ein mutiger "Angreifer" mit wenig Entwicklungs- und Prozess-Know-how ergreift nicht zu selten die Initiative und stellt selbst triumphierend das Produkt seiner Wünsche her. Es ist in der Tat nicht schwer, schnell das gewünschte Ergebnis zum Beispiel in Form eines Triggers zu erzielen. Im Internet kursieren viele Beispiele dazu. Die mächtige Salesforce Community unterstützt im Problemfall. Einige Lösungen aus dieser Kategorie durfte ich in den letzten Jahren begutachten. Sie alle haben eine Gemeinsamkeit: sie funktionieren nicht (lange)! Da fühlt man sich manchmal wie die Stiftung Warentest, die ein chinesisches Billigprodukt testet. Ziel als Ausgangspunkt

Crazy SOQL

Genauso habe ich heute geschaut, als ich den folgenden Code ausgeführt und das Ergebnis ausgewertet habe: CustomObj__c obj = [select LookupField__c from CustomObj__c where LookupField__c != NULL AND Id = 'hereisavalidid']; system.debug(' LookupField__c darf nicht NULL sein '); if(obj.LookupField__c == null){     system.debug(' Also doch NULL '); } Und was sehen meine müde Augen im Log... LookupField__c ist ein Lookup- und Pflichtfeld, somit darf eigentlich per Definition nicht NULL sein. Offensichtlich gibt es (alte) Daten im System mit dem  LookupField__c = NULL Habe erwartet, dass die SOQL Abfrage die NULL-Daten filtert.

Bad value for restricted picklist field

Der Einsatz von "Restricted Picklists" bereitet spätestens im Deployment Kopfschmerzen. Basiert das Deployment auf Basis eines Drittanbietertools, dann sind die Kopfschmerzen noch intensiver. In meinem Fall habe ich versucht, ein neues Picklist-Feld mit Copado zu deployen. Während der Bereitstellung bekomme ich die folgende Fehlermeldung: System.DmlException: Insert failed. First exception on row 0; first error: INVALID_OR_NULL_FOR_RESTRICTED_PICKLIST, bad value for restricted picklist field: Z012: [CountryGroup__c] Das neue Picklist-Feld übernimmt alle Werte aus einem Global Value Set. Das bedeutet, die Option "Restrict to the values defined in the value set" ist automatisch aktiv und lässt sich nicht deaktivieren. Eine APEX-Testklasse beschreibt ebenfalls die neue Pickliste. Mit dem folgenden Workaround konnte ich das Deployment-Problem lösen: 1) Global Value Set samt Pickliste per Changeset in die Zielorg übertragen und bereitstellen ggf. Prof