Definir las reglas de habilitación de la cinta de opciones
Nota
Este tema trata sobre comandos clásicos.
Hay una nueva forma de definir comandos. Consulte Información general de los comandos modernos (versión preliminar)
Al configurar los elementos de la cinta de opciones, se pueden definir las reglas para supervisar cuando se habilitan los elementos de la cinta de opciones. El elemento <EnableRule>
se usa de la siguiente manera:
- Use el elemento
/RuleDefinitions/EnableRules/EnableRule
para definir las reglas que controlan cuándo debe habilitarse el elemento de la cinta de opciones. - Use el elemento
/CommandDefinitions/CommandDefinition/EnableRules/EnableRule
para asociar reglas de habilitación específicas a una definición de comando.
¿Qué significa estar habilitado?
En la barra de comandos, los comandos deshabilitados están ocultos. En la cinta de opciones, los comandos deshabilitados están visibles pero no responden a eventos.
Controlar cuando los elementos de la cinta de opciones están habilitados
Las reglas de habilitación están pensadas para que puedan reutilizarse. Al definirlas con definiciones de reglas, se puede usar la misma regla de habilitación para muchas definiciones de comando. Cuando más de una regla de habilitación está definida para una definición de comando, todas las reglas de habilitación deben evaluarse como true para que el elemento de la cinta de opciones esté habilitado.
Todas las reglas Enable proporcionan un parámetro opcional para especificar si el valor predeterminado de la regla es true o false, y un parámetro InvertResult
opcional para habilitar la devolución de un resultado negativo cuando el elemento que se está probando devuelve true.
El elemento /RuleDefinitions/EnableRules/EnableRule
admite los siguientes tipos de reglas:
Regla de tipo de cliente de comando
Usa el elemento <CommandClientTypeRule>
. Especifica una regla que detecta el tipo de presentación que se usa.
Los valores Type
corresponden a lo siguiente:
valor | Presentación |
---|---|
Modern |
La barra de comandos se muestra mediante Dynamics 365 for tablets. |
Refresh |
La barra de comandos se muestra mediante la interfaz de usuario actualizada. |
Legacy |
La cinta de opciones se muestra en los formularios de tablas que no se actualizaron o en una vista de lista en Dynamics 365 for Outlook. |
Regla de tipo de cliente CRM
Usa el elemento <CrmClientTypeRule>
para permitir la definición de reglas en función del tipo de cliente utilizado. Las opciones de tipo son las siguientes:
Web
Outlook
Regla de estado de acceso sin conexión de CRM
Usa el elemento <CrmOfflineAccessStateRule>
. Use este criterio para habilitar un elemento de la cinta de opciones en función de si Dynamics 365 for Microsoft Office Outlook con acceso sin conexión está actualmente sin conexión.
Regla de tipo de cliente Outlook de CRM
Usa el elemento <CrmOutlookClientTypeRule>
. Use esta regla si desea mostrar solo un botón para un tipo específico de Dynamics 365 for Outlook. Las opciones de tipo son las siguientes:
CrmForOutlook
CrmForOutlookOfflineAccess
Regla personalizada
Usa el elemento <CustomRule>
. Use este tipo de regla para llamar a una función en un recurso web JavaScript que devuelva una promesa (interfaz unificada) o un valor booleano (interfaz unificada y cliente web).
function EnableRule()
{
const value = Xrm.Page.getAttribute("column1").getValue();
return value === "Active";
}
Nota
Las reglas personalizadas que no devuelven un valor rápidamente pueden afectar al rendimiento de la cinta de opciones. Si tiene que realizar lógica que puede tardar algún tiempo en completarse (por ejemplo, una solicitud de red), use la siguiente estrategia para crear su regla personalizada asincrónica.
La reglas de la interfaz unificada admiten que se devuelva una promesa más que un valor booleano para la evaluación de reglas asincrónica. Si la promesa no se resuelve en 10 segundos, la regla se resolverá con un valor false.
Nota
Las reglas basadas en promesas solo funcionarán en la interfaz unificada, por lo que no se pueden usar si se sigue utilizando el típico cliente web.
// Old synchronous style
/*
function EnableRule() {
const request = new XMLHttpRequest();
request.open('GET', '/bar/foo', false);
request.send(null);
return request.status === 200 && request.responseText === "true";
}
*/
// New asynchronous style
function EnableRule() {
const request = new XMLHttpRequest();
request.open('GET', '/bar/foo');
return new Promise(function(resolve, reject) {
request.onload = function (e) {
if (request.readyState === 4) {
if (request.status === 200) {
resolve(request.responseText === "true");
} else {
reject(request.statusText);
}
}
};
request.onerror = function (e) {
reject(request.statusText);
};
request.send(null);
});
}
Regla de entidad
Usa el elemento <EntityRule>
. EntityRule
permite la evaluación de la tabla actual. Esto resulta útil al definir acciones personalizadas que se aplican a la plantilla de la tabla en lugar de a las tablas específicas. Por ejemplo, es posible que desee agregar un elemento de la cinta de opciones en todas las tablas excepto en algunas tablas específicas. Es más fácil definir la acción personalizada de la plantilla de la tabla que se aplica a todas las tablas y después usar una regla EntityRule
para filtrar aquellas que se deben excluir.
Las reglas EntityRule
también incluyen un parámetro de contexto opcional para especificar si se muestra la tabla en el formulario o en una lista (HomePageGrid). El parámetro opcional AppliesTo
se puede establecer en PrimaryEntity
o en SelectedEntity
para distinguir si se muestra la tabla en una subcuadrícula.
Regla de estado del formulario
Usa el elemento <FormStateRule>
. Use la regla FormState
para determinar el tipo actual de formulario que se muestra en un registro. Las opciones de estado son las siguientes:
Create
Existing
ReadOnly
Disabled
BulkEdit
Regla O
Usa el elemento <OrRule>
. OrRule
permite reemplazar el valor de comparación predeterminado AND para varios tipos de reglas de habilitación. Use el elemento OrRule
para definir varias combinaciones posibles válidas para comprobar.
Regla de seguimiento de elementos de Outlook
Usa el elemento <OutlookItemTrackingRule>
. Use el parámetro TrackedInCrm
de este elemento para determinar si se realiza el seguimiento del registro en Power Apps.
Regla de la versión de Outlook
Usa el elemento <OutlookVersionRule>
. Use esto para habilitar un elemento de la cinta de opciones de una versión específica de Office Outlook, de la siguiente manera:
2003
2007
2010
Regla de página
Usa el elemento <PageRule>
. Este tipo de regla compruebe la dirección URL de la página que se muestra. Devuelve true si coincide con Address
.
Regla de privilegios de registro
Usa el elemento <RecordPrivilegeRule>
. Use esta regla para determinar si el usuario actual tiene privilegios en un registro específico. Estos privilegios difieren del privilegio de la tabla porque pueden incluir los privilegios obtenidos por otro usuario que comparte el registro con el usuario actual.
Regla de recuento de selección
Usa el elemento <SelectionCountRule>
. Use este tipo de regla con una cinta de opciones para que aparezca una lista para habilitar un botón cuando se seleccionan los números de registros máximos y mínimos específicos en la cuadrícula. Por ejemplo, si el botón combina los registros, debe asegurarse de que al menos dos registros están seleccionados antes de habilitar el control de la cinta de opciones.
Regla de valor
Usa el elemento <ValueRule>
. Use esta regla para comprobar el valor de una columna específica en el registro que se muestra en el formulario. Debe especificar Field
y Value
para comprobar.
Nota
En un formulario, un ValueRule
requiere que la columna especificada sea parte del formulario para que funcione. En una cuadrícula o subcuadrícula, la columna debe ser una de las columnas de la cuadrícula.
Mostrar en la regla de acción rápida
Usa el elemento <EnableRule>
. Utilice esta regla para que el comando aparezca solo como una acción rápida.
<CommandDefinition Id="new.contact.Command.Call">
<EnableRules>
<EnableRule Id="Mscrm.SelectionCountExactlyOne" />
<EnableRule Id="Mscrm.ShowOnQuickAction" />
</EnableRules>
<DisplayRules />
<Actions>
<JavaScriptFunction FunctionName=" simplealert" />
</Actions>
</CommandDefinition>
Mostrar en la cuadrícula de la regla de acción rápida
Usa el elemento <EnableRule>
. Utilice esta regla para que el comando aparezca en la cuadrícula de la página de inicio y como acción rápida.
<CommandDefinition Id="new.contact.Command.Call">
<EnableRules>
<EnableRule Id="Mscrm.SelectionCountExactlyOne" />
<EnableRule Id="Mscrm.ShowOnGridAndQuickAction" />
</EnableRules>
<DisplayRules />
<Actions>
<JavaScriptFunction FunctionName=" simplealert" />
</Actions>
</CommandDefinition>
Mostrar en la regla de cuadrícula
Usa el elemento <EnableRule>
. Utilice esta regla para que el comando de acción rápida aparezca solo en la cuadrícula de la página de inicio. En otras palabras, puede utilizar este comando para ocultar una acción rápida existente.
<CommandDefinition Id="new.contact.Command.Call">
<EnableRules>
<EnableRule Id="Mscrm.SelectionCountExactlyOne" />
<EnableRule Id="Mscrm.ShowOnGrid" />
</EnableRules>
<DisplayRules />
<Actions>
<JavaScriptFunction FunctionName=" simplealert" />
</Actions>
</CommandDefinition>
Consultar también
Personalización de comandos y la cinta de opciones
Definir comandos de la cinta de opciones
Defina las reglas de la visualización de la cinta de opciones