Cómo localizar tu modelo de LookML

Con la localización de modelos, puedes personalizar la forma en que se muestran las etiquetas y descripciones de tu modelo según la configuración regional del usuario.

No es necesario que la localización esté basada en la ubicación geográfica ni en el idioma. Puedes usar configuraciones regionales para representar otros factores distintivos, como usuarios internos o externos, o administradores y colaboradores individuales, y personalizar tus etiquetas y descripciones en consecuencia.

En esta página, se describen los pasos para localizar tu proyecto:

  1. Para determinar qué elementos se localizarán, agrega etiquetas, etiquetas de grupo y descripciones a tu modelo.
  2. Proporciona las definiciones de localización de tu proyecto creando archivos de cadenas de configuración regional.
  3. Para habilitar la localización de tu proyecto, agrega la configuración de localización al archivo de manifiesto del proyecto.
  4. Asigna usuarios a configuraciones regionales para determinar la visualización de los diferentes usuarios.

La localización de modelos suele realizarse junto con un administrador que especifica la configuración de localización del formato de número y del idioma de la interfaz de usuario.

Localiza etiquetas y descripciones en tu modelo

Puedes localizar etiquetas, etiquetas de grupo y descripciones en tu modelo, incluidos los siguientes elementos:

También puedes crear paneles de LookML localizados en tu proyecto. Los siguientes parámetros del panel de LookML pueden localizarse:

Para ver todos los campos de tu proyecto que se pueden localizar, puedes configurar el nivel de localización del proyecto como strict. Con este parámetro de configuración, el IDE de Looker muestra un error de validación de LookML para los elementos de LookML que se pueden localizar, pero que no tienen etiquetas, y para las cadenas de tu modelo de LookML que se pueden localizar, pero que no están definidas en tus archivos de cadenas de configuración regional.

En el siguiente ejemplo de LookML, se proporcionan etiquetas para la vista flights y los campos id, country y number_of_engines. También se proporciona una descripción para el campo country.

view: flights {
  label: "flight_info"
  sql_table_name: flightstats.accidents ;;

  dimension: id {
    label: "id"
    primary_key: yes
    type: number
    sql: ${TABLE}.id ;;
  }

  dimension: country {
    label: "country"
    description: "country_of_departure"
    type: string
    map_layer_name: countries
    sql: ${TABLE}.country ;;
  }

  dimension: number_of_engines {
    label: "number_of_engines"
    type: string
    sql: ${TABLE}.number_of_engines ;;
  }

  dimension: location {
    type: string
    sql: ${TABLE}.location ;;
  }

En los ejemplos que se muestran a continuación en esta página, localizaremos estos valores en los archivos de cadenas con un nivel de localización permissive. Ten en cuenta que la dimensión location no tiene una etiqueta, por lo que podemos demostrar cómo se muestra una dimensión sin localización.

Cómo crear archivos de cadenas de configuración regional

Los archivos de cadenas de configuración regional usan pares clave-valor para definir cómo se muestran las etiquetas y descripciones de tu modelo para cada configuración regional. En el lado izquierdo de cada par clave-valor, se encuentra la clave de localización, que es una etiqueta o una cadena de descripción de tu modelo. En el lado derecho del par clave-valor, puedes definir cómo deseas que se muestre esa cadena en la IU de Looker.

Para cada configuración regional que quieras usar en tu proyecto, debes crear un archivo de cadenas dedicado. Crea solo un archivo de cadenas para cada configuración regional. Debes tener un archivo de cadenas con un nombre que coincida con la configuración regional predeterminada. Por ejemplo, si especificaste default_locale: en en el archivo de manifiesto de tu proyecto, debes tener un archivo en tu modelo llamado en.strings.json. Cada cadena debe definirse en el archivo de cadenas de configuración regional predeterminada; de lo contrario, no se localizará.

Este ejemplo de un archivo en.strings.json se usará para todos los usuarios que tengan el valor en para Locale. En el siguiente ejemplo de LookML, en también se especifica como la configuración regional predeterminada, por lo que todas las cadenas deben definirse en este archivo para que se puedan localizar.

{
  "flight_info": "Flights",
  "id": "Identifier",
  "country_of_departure": "Country of Departure",
  "number_engines": "Number of Engines"
}

En la siguiente tabla, se muestra lo que un usuario con su configuración regional establecida en en vería en la tabla de datos de una exploración de Looker:

Flights Identifier Flights country Flights Location Flights Number of Engines
493 Congo Kisangani, Congo 3
2167 Saudi Arabia Riyadh, Saudi Arabia 3
2657 Austria Vienna, Austria 2
17992 United States Kansas City, MO 2
18893 United States Anchorage, AK 4

Ten en cuenta lo siguiente:

  • En el LookML de muestra de flights que mostramos anteriormente, no proporcionamos ninguna etiqueta para la dimensión location, por lo que Looker muestra el nombre de la dimensión en mayúsculas: “Ubicación”.
  • No definimos la localización para el "país". etiqueta de nuestro archivo en.strings.json, para que Looker muestre la etiqueta como está definida en nuestro archivo de vista, sin mayúsculas: “country”.

Como otro ejemplo, podemos crear un archivo es_ES.strings.json que se use para todos los usuarios con un valor de Locale de es_ES:

{
  "flight_info": "Vuelos",
  "id": "Identificador",
  "country": "País",
  "country_of_departure": "País de Partida",
  "number_engines": "Número de Motores"
}

En la siguiente tabla, se muestra lo que vería en Looker un usuario con la configuración regional establecida en es_ES:

Vuelos Identificador Vuelos country Vuelos Location Vuelos Número de Motores
493 Congo Kisangani, Congo 3
2167 Saudi Arabia Riyadh, Saudi Arabia 3
2657 Austria Vienna, Austria 2
17992 United States Kansas City, MO 2
18893 United States Anchorage, AK 4

Ten en cuenta lo siguiente:

  • Al igual que en el ejemplo anterior, en la vista original con etiquetas y descripciones agregadas, no proporcionamos una etiqueta en absoluto para la dimensión location, por lo que Looker muestra el nombre de la dimensión en mayúsculas: “Ubicación”.
  • No definimos la localización para el "país". etiqueta en nuestro archivo en.strings.json, que es el archivo de cadenas de configuración regional predeterminado. Por lo tanto, aunque definimos "country" en nuestro archivo es_ES.strings.json, Looker no localiza esta cadena y muestra la etiqueta como se define en nuestro archivo de vista: "country".

Agrega la configuración de localización al archivo de manifiesto de tu proyecto

Para habilitar la localización de tu proyecto, agrega el parámetro localization_settings al archivo de manifiesto de tu proyecto.

En el archivo de manifiesto, agrega tu configuración de localización. A continuación, se presenta un ejemplo:

localization_settings: {
  default_locale: en
  localization_level: permissive
}

default_locale

El parámetro default_locale especifica el nombre del archivo de cadenas de configuración regional predeterminada de tu proyecto.

El archivo de cadenas de configuración regional predeterminada determina qué cadenas de tu modelo están localizadas. Incluso si una etiqueta o una cadena de descripción se definen en otro archivo de cadenas de configuración regional, si no se definen en el archivo de cadenas de configuración regional predeterminada, la IU de Looker mostrará la cadena no localizada.

No debes confundir la configuración regional predeterminada de tu proyecto con la configuración regional predeterminada para los usuarios de Looker. El administrador de Looker puede establecer una configuración regional predeterminada para tu instancia. Si no se establece un valor predeterminado, Looker usará en de forma predeterminada. Si tu administrador no ingresa específicamente un valor de Locale para un usuario o un grupo de usuarios al que pertenece el usuario, Looker lo asigna a la configuración regional predeterminada de la instancia. Además, si el administrador no estableció una configuración regional predeterminada para la instancia, Looker asigna al usuario a la configuración regional en.

Por este motivo, a menos que estés seguro de que tu administrador de Looker establecerá el valor de Locale para todos los usuarios de Looker, debes establecer el parámetro default_locale de tu proyecto en la configuración regional predeterminada de tu instancia (o en en si no se estableció una configuración predeterminada) y definir la localización de todas tus etiquetas y descripciones en el archivo .strings.json de esa configuración regional.

localization_level

El nivel de localización de tu proyecto especifica si el modelo permite elementos no localizados:

  • Establece el nivel de localización en strict para exigir etiquetas localizadas para todos los modelos, Exploraciones, vistas y campos de tu proyecto. El IDE de Looker mostrará un error de validación de LookML para cualquiera de estos elementos que no tengan etiquetas y para las etiquetas y descripciones que no estén definidas en el archivo de cadenas de configuración regional predeterminado.
  • Establece el nivel de localización en permissive para permitir elementos sin etiquetas y etiquetas y descripciones que no estén definidas en el archivo de cadenas de localización predeterminado.

Incluso si deseas el nivel de localización strict, puede ser útil establecer el nivel de localización de tu proyecto en permissive cuando lo desarrolles para evitar errores de validación. Cuando termines de localizar todas las etiquetas y descripciones, puedes establecer el nivel de localización en strict para ver los errores.

Cómo asignar usuarios a una configuración regional

Una vez que hayas configurado tus archivos de cadenas de configuración regional, podrás asignar a los usuarios a una configuración regional que corresponda a uno de los archivos de cadenas de configuración regional. Esto se puede hacer a nivel de instancia, grupo de usuarios o usuario individual, con el campo Configuración regional o el atributo de usuario locale.

Por ejemplo, si deseas que un usuario vea las etiquetas y descripciones definidas en el archivo es_ES.strings.json, el administrador de Looker debe establecer el parámetro de configuración Locale del usuario en es_ES.

Para ingresar las configuraciones regionales personalizadas que crees con archivos de cadena, haz clic en el campo y escribe el nombre del archivo de cadena en lugar de seleccionar una configuración regional integrada en el menú desplegable en el campo Locale. Para obtener más información, consulta la página de documentación de Usuarios.

Configuración de la configuración regional para los usuarios incorporados firmados

Puedes incluir el valor de configuración regional de un usuario en una URL de incorporación firmada como cualquier otro atributo del usuario. El formato exacto requerido para las incorporaciones firmadas depende del lenguaje de programación que se usa para compilar la secuencia de comandos de la URL de incorporación firmada, pero el nombre del atributo de usuario es locale. Consulta la página de documentación sobre las incorporaciones firmadas para obtener más información sobre las URL de incorporación firmadas y las herramientas para compilar tu URL de incorporación firmada.

Usa la configuración regional en variables líquidas

Como se describió anteriormente, la localización de modelos te permite personalizar la visualización de las etiquetas y descripciones de tu modelo para diferentes configuraciones regionales. Sin embargo, también puedes incluir claves de localización en las variables líquidas, lo que te permite localizar tus valores de datos.

Por ejemplo, en nuestro archivo de cadenas de configuración regional predeterminado llamado en.strings.json, podemos crear las claves de localización domestic y international con las siguientes entradas:

{
  "domestic": "Domestic",
  "international": "International"
}

Luego, en nuestro archivo es_ES.strings.json, podemos proporcionar versiones en español de estas claves de localización:

{
  "domestic": "Nacional",
  "international": "Internacional"
}

A partir de ahí, podemos usar las claves de localización domestic y international en las variables de Liquid para localizar el resultado de una dimensión:

dimension: from_US {
    label: "from_us"
    type: string
    sql: CASE
         WHEN ${TABLE}.country = 'United States' THEN '{{ _localization['domestic'] }}'
         ELSE '{{ _localization['international'] }}'
         END;;
  }

Los usuarios que tengan la configuración regional en verán los siguientes resultados:

Flights Identifier Flights country Flights From the US?
289 United States Domestic
400 Canada International
493 Congo International
936 United States Domestic

Los usuarios que tengan la configuración regional es_ES verán los siguientes resultados:

Vuelos Identificador Vuelos País Vuelos ¿De Los Estados Unidos?
289 United States Nacional
400 Canada Internacional
493 Congo Internacional
936 United States Nacional

Los usuarios con la configuración regional es_ES ven los datos "Nacional" e "Internacional" localizados a "Nacional" e "Internacional", respectivamente.

También puedes usar Liquid en los filtros de panel de LookerML y los filtros de elementos de panel de LookerML para localizar el valor predeterminado en un filtro. Por ejemplo, si un panel de LookML tiene un mosaico que usa datos de este modelo localizado y hay un filtro en ese mosaico definido en LookML de la siguiente manera:

filters:
  flights.from_US: "{{ _localization['domestic'] }}"

Cuando un usuario con la configuración regional en explora desde ese mosaico del panel, Explorar se filtrará en el valor Domestic del campo Flights From the US?, y la tabla de datos de Explorar incluirá los siguientes resultados:

Flights Identifier Flights country Flights From the US?
289 United States Domestic
936 United States Domestic

Cuando un usuario con la configuración regional es_ES explora desde esa tarjeta del panel, la función Explora se filtra en el valor Nacional para el campo Vuelos ¿De Los Estados Unidos?, y la tabla de datos de la función Explora incluirá los siguientes resultados:

Vuelos Identificador Vuelos País Vuelos ¿De Los Estados Unidos?
289 United States Nacional
936 United States Nacional

Comprende cómo se aplican las reglas de localización a los objetos extendidos y refinados

Ten en cuenta que las reglas de localización se aplican cuando extiendes vistas, Exploraciones o paneles de LookML, y cuando defines mejor vistas o Exploraciones.

Si extendiste o definiste mejor un objeto y, luego, agregaste etiquetas o descripciones nuevas, debes proporcionar definiciones de localización en los archivos de cadenas de configuración regional.

Por ejemplo, si tenemos una vista flights:


view: flights {
  label: "flight_info"
  sql_table_name: flightstats.accidents ;;
  ...
}

Luego, creamos una vista nueva que extiende la vista flights:

include: "/views/flights.view"

view: flights_enhanced {
  extends: [flights]
  label: "enhanced_flight_info"
}

En nuestros archivos de cadenas de configuración regional, debemos definir ambas cadenas de etiqueta de vista ("flight_info" y "enhanced_flight_info"). Si el nivel de localización del proyecto es strict, no podremos confirmar ninguna actualización hasta que definamos las nuevas etiquetas o descripciones.