Differences
This shows you the differences between two versions of the page.
customization:lime-links [2016-03-08 12:33] Martin Berg Page moved from customization:lime-links to relnotes:releases:customization:lime-links |
customization:lime-links [2018-12-02 22:09] |
||
---|---|---|---|
Line 1: | Line 1: | ||
- | ====== LIME links ====== | ||
- | LIME links are direct shortcuts to a record or a feature in LIME Pro. Examples of where LIME links are used in LIME Pro is in the " | ||
- | You can also build your own LIME links. The following links could for example be embedded in web page: | ||
- | |||
- | < | ||
- | |||
- | < | ||
- | |||
- | ===== Format ===== | ||
- | A LIME link follows this formatting scheme: | ||
- | |||
- | < | ||
- | |||
- | ^ Parameter ^ Description ^ | ||
- | | CLASS | Database name or label of a LIME table.| | ||
- | | DATABASE | The name of the LIME Pro database. | | ||
- | | LIMESERVER | The name of the LIME Pro server. | | ||
- | | COMMAND | The command to execute. | | ||
- | | PARAMETER | Parameter name. Every command accepts different parameters, more info below. | | ||
- | | VALUE | The value to use for the specified parameter. | | ||
- | |||
- | An example of a LIME link that opens a specific record and where CLASS refers to the database name of a table: | ||
- | < | ||
- | |||
- | If a table label were to be used instead the link should look like this: | ||
- | < | ||
- | |||
- | Executing the link will open the company record having ID 1001 in the database // | ||
- | |||
- | ===== Built-in commands ===== | ||
- | ==== Open ==== | ||
- | The //open// command opens the specified record in LIME Pro. The record ID must be specified as a parameter having the name // | ||
- | |||
- | Available parameters: | ||
- | |||
- | ^ Parameter ^ Description ^ | ||
- | | idrecord/ | ||
- | | activeexplorer | Specifies which tab that is to be set as the active tab when the record is opened. Note that it is the name of the relation field that should be specified here. | | ||
- | | field/value pair | Use only if the record ID is not available. LIME Pro will try to search for the record to open using the information as conditions in a filter. Only the first matching record will be shown. | | ||
- | |||
- | === Examples === | ||
- | Open the company having record ID 1001 in the // | ||
- | < | ||
- | |||
- | The short version: | ||
- | < | ||
- | |||
- | Open the company having the name // | ||
- | < | ||
- | |||
- | Note that all values need to be URI encoded. The VBA function '' | ||
- | |||
- | ==== New ==== | ||
- | The //new// command creates a new record and can also open it afterwards. To create a new history record associated with a company: | ||
- | |||
- | < | ||
- | |||
- | Available parameters (all optional): | ||
- | |||
- | ^ Parameter ^ Description ^ | ||
- | | ownerclass | The name of the class of the parent record. | | ||
- | | ownerid | The ID of the parent record. | | ||
- | | ownersource | The parent record ID can be automatically set by LIME Pro. Valid values are '' | ||
- | | ownerfield | The name of the field that links to the parent record. If not specified LIME Pro will attempt to autodetect this. | | ||
- | | autosave | When set to '' | ||
- | | field/value pair | Specify values for fields in the record. | | ||
- | |||
- | === Examples === | ||
- | Create a new history record: | ||
- | |||
- | < | ||
- | |||
- | Create a new history record with the company having ID 1001 as parent: | ||
- | < | ||
- | |||
- | Create a new history record with the select company as the parent and the text //Talked to Lisa Johnson// as the text and the alternative //Sales call// as category: | ||
- | < | ||
- | |||
- | ==== MailTo ==== | ||
- | The //mailto// command creates a new e-mail message in the same manner as when an e-mail address is clicked by the user in LIME Pro. The following link creates an e-mail for //Nisse// at // | ||
- | |||
- | < | ||
- | |||
- | Available parameters (all optional): | ||
- | |||
- | ^ Parameter ^ Description ^ | ||
- | | idrecord/ | ||
- | | field | Specifies the name of the field to fetch the recipient e-mail address from. When using this parameter '' | ||
- | | address | Recipient e-mail address. | | ||
- | | subject | E-mail message subject. | | ||
- | | body | E-mail message body. | | ||
- | | flags | A combination of values from the '' | ||
- | |||
- | ==== CallTo ==== | ||
- | By using the //callto// command LIME Pro is instructed to dial the specified phone number. This can typically be used to easily dial a number from an action pad. | ||
- | |||
- | The following is a LIME link that dials Lundalogik Customer Support when executed: | ||
- | |||
- | < | ||
- | |||
- | Available parameters: | ||
- | |||
- | ^ Parameter ^ Description ^ | ||
- | | number | The number to dial. | | ||
- | |||
- | ==== Appointment ==== | ||
- | The '' | ||
- | |||
- | The following example creates an appointment with the person having record ID 1001 and sets the subject to //LIME Pro kick-off//: | ||
- | |||
- | < | ||
- | |||
- | Note that the '' | ||
- | |||
- | Available parameters (all optional): | ||
- | |||
- | ^ Parameter ^ Beskrivning ^ | ||
- | | ownerclass | The name of the class that the appointment concerns. Typically used with classes having the company or person labels set but can also be used with other classes. In those cases the system will attempt to autodetect a suitable name, person or company associated with the specified record. | | ||
- | | ownerid | ID of the record that the appointment should be associated with. Supports persons and companies, otherwise the behavior specified above will be used. | | ||
- | | subject | Appointment subject. | | ||
- | |||
- | === Examples === | ||
- | Create a new, empty appointment: | ||
- | < | ||
- | |||
- | Create a new appointment with the person having record ID 1001: | ||
- | < | ||
- | |||
- | Create a new appointment with the company having record ID 2001: | ||
- | < | ||
- | |||
- | Create a new appointment with the company having record ID 2001 and set the subject to //LIME Pro kick-off//: | ||
- | < | ||
- | |||
- | Create a new appointment for an activity having record ID 3001. Note that the behavior here is completely dependent on the database structure since the // | ||
- | < | ||
- | |||
- | ==== Log ==== | ||
- | The //log// command adds a new log record to the // | ||
- | |||
- | < | ||
- | |||
- | Available parameters: | ||
- | |||
- | ^ Parameter ^ Description ^ | ||
- | | type | Specifies the log severity. Specify one of the following (numeric) values: | ||
- | '' | ||
- | '' | ||
- | '' | ||
- | '' | ||
- | '' | ||
- | | source | Name the application or module reporting the error. | | ||
- | | location | Description of where the logging was performed. | | ||
- | | number | Error code. | | ||
- | | message | Log message. | | ||
- | |||
- | ===== Custom commands ===== | ||
- | In addition to the built-in commands it is possible to define custom commands that are processed in VBA by listening to and handling the '' | ||
- | |||
- | ^ Parameter ^ Data type ^ Description ^ | ||
- | | Class | LDE.Class | The class that the LIME link concerns. | | ||
- | | Command | String | The name of the command. | | ||
- | | Parameter | String | The parameter string. | | ||
- | | Handled | Boolean | Should be set to '' | ||
- | |||
- | Given the following LIME link: | ||
- | |||
- | < | ||
- | |||
- | ...the event parameters will receive the following values: | ||
- | |||
- | ^ Parameter ^ Value ^ | ||
- | | Class | The '' | ||
- | | Command | mycommand | | ||
- | | Parameter | command=mycommand& | ||
- | |||
- | === Example === | ||
- | The following code sample shows how a custom command that opens a web browser with the URL set to the contents of any present field having the " | ||
- | |||
- | <code vb> | ||
- | Private Sub Application_ExecuteURL(ByVal Class As LDE.IClass, ByVal Command As String, ByVal Parameters As String, | ||
- | |||
- | ' | ||
- | ' | ||
- | |||
- | Dim fieldUrl As LDE.Field | ||
- | Dim rec As LDE.Record | ||
- | Dim viewUrl As LDE.View | ||
- | Dim i As Integer | ||
- | Dim parameter As String | ||
- | Dim parameterArray() As String | ||
- | Dim recordId As Long | ||
- | |||
- | If Command = " | ||
- | ' | ||
- | Set fieldUrl = Class.Fields.Lookup(FieldLabelEnum.lkFieldLabelBusinessHomePage, | ||
- | | ||
- | |||
- | If Not fieldUrl Is Nothing Then | ||
- | ' | ||
- | |||
- | | ||
- | |||
- | For i = LBound(parameterArray) To UBound(parameterArray) | ||
- | If Left(parameterArray(i), | ||
- | | ||
- | Exit For | ||
- | End If | ||
- | Next | ||
- | |||
- | If recordId <> 0 Then | ||
- | ' | ||
- | |||
- | Set rec = New LDE.Record | ||
- | Set viewUrl = New LDE.View | ||
- | |||
- | | ||
- | |||
- | | ||
- | |||
- | If Len(rec(fieldUrl.Name)) > 0 Then | ||
- | ' | ||
- | Shell rec(fieldUrl.Name) | ||
- | |||
- | ' | ||
- | | ||
- | Else | ||
- | | ||
- | End If | ||
- | End If | ||
- | End If | ||
- | End If | ||
- | |||
- | End Sub | ||
- | </ | ||
- | |||
- | ===== Javascript support ===== | ||
- | To simplify the creation and execution of LIME links Lundalogik provides a Javascript helper class that can be found in the '' | ||
- | |||
- | ==== Execute ==== | ||
- | This function can be used with all commands and has the advantage that only one call to LimeUrl needs to be done to both create and execute the link command. | ||
- | |||
- | '' | ||
- | |||
- | ^ Parameter ^ Description ^ | ||
- | | classname | The class that the command should operate on. | | ||
- | | command | The command to execute. | | ||
- | | options | An object with parameters to the command. All parameters need to be named and have a value. This object can also have a member called '' | ||
- | |||
- | === Examples === | ||
- | Open the company record having ID 1001 and set the tab pointed to by the // | ||
- | <code javascript> | ||
- | LimeUrl.Execute(' | ||
- | | ||
- | | ||
- | }); | ||
- | </ | ||
- | |||
- | Create a new history record and associate it with the currently selected company record: | ||
- | <code javascript> | ||
- | LimeUrl.Execute(' | ||
- | | ||
- | | ||
- | }); | ||
- | </ | ||
- | |||
- | The same as above, but for embedded use in e.g. an actionpad: | ||
- | <code html> | ||
- | <a href="#" | ||
- | | ||
- | | ||
- | | ||
- | </ | ||
- | ==== Create ==== | ||
- | Creates a LIME link with the specified command as its only parameter. | ||
- | |||
- | '' | ||
- | |||
- | ^ Parameter ^ Description ^ | ||
- | | classname | Name of the class the link concerns. | | ||
- | | command | The command that the link should execute. | | ||
- | |||
- | === Example === | ||
- | To create a link that creates a new history record: | ||
- | <code javascript> | ||
- | LimeUrl.Create(' | ||
- | </ | ||
- | This results in the following link: | ||
- | < | ||
- | limecrm: | ||
- | </ | ||
- | |||
- | ==== AddParameter ==== | ||
- | Adds a parameter to a link that was created using a call to '' | ||
- | |||
- | '' | ||
- | |||
- | ^ Parameter ^ Description ^ | ||
- | | name | Name of the parameter. | | ||
- | | value | Value of the parameter. | | ||
- | |||
- | === Example === | ||
- | To add parent record and contact person to the link that was created in the previous example: | ||
- | |||
- | <code javascript> | ||
- | LimeUrl.AddParameter(' | ||
- | LimeUrl.AddParameter(' | ||
- | LimeUrl.AddParameter(' | ||
- | </ | ||
- | This results in the following link: | ||
- | < | ||
- | limecrm: | ||
- | |||
- | ==== Click ==== | ||
- | Executes the LIME link created using '' | ||
- | |||
- | === Example === | ||
- | <code javascript> | ||
- | LimeUrl.Click(); | ||
- | </ |