Pular para o conteúdo principal

Tutorial: Demonstração de todos os widgets da interface do usuário

info

Visualização

Este recurso está em Pré-visualização Pública.

Este tutorial de referência cria um operador UDF Python para o LakeFlow Designer que utiliza todos os widgets de interface do usuário disponíveis no esquema user-defined-operator-v0.1.0 . Use-o como padrão ao criar seus próprios operadores. Para uma visão geral mais ampla, consulte Operadores definidos pelo usuário no LakeFlow Designer.

Visão geral

Este operador é uma UDF de demonstração que aceita parâmetros usando todos os tipos de widgets de interface do usuário disponíveis. Ele concatena todos os valores de entrada em strings descritivas, facilitando a visualização de como cada widget passa dados para sua função.

Os tipos de widgets disponíveis são:

Widget

Descrição

Tipo de dados

expression

Seletor de coluna/expressão da porta de entrada

expressão

input

Entrada de texto em linha única

string

textarea

Área de texto com várias linhas

string

checkbox

caixa de seleção

Booleana

toggle

Interruptor de alternância

Booleana

number

Entrada de número com mínimo/máximo

Número

slider

Controle deslizante numérico com intervalo

Número

select

dropdown de seleção única (valores estáticos)

string

select

dropdown de seleção única (a partir de colunas de entrada)

string

multi-select

Seleção múltipla (valores estáticos)

strings[]

multi-select

Seleção múltipla (a partir de colunas de entrada)

strings[]

Passo 1: Escreva e teste a função Python

Primeiro, defina a função em Python que aceita todos os diferentes tipos de parâmetros. Essa função simplesmente concatena todas as entradas em strings descritivas para fins de demonstração.

Python
def concat_all_widgets(
# expression widget - column value from input
expr_value: str,
# input widget - single line text
text_input: str,
# textarea widget - multi line text
text_area: str,
# checkbox widget - boolean
checkbox_flag: bool,
# toggle widget - boolean
toggle_flag: bool,
# number widget - numeric input
number_value: float,
# slider widget - numeric slider
slider_value: float,
# select widget with static options
select_static: str,
# select widget with inputColumns options
select_column: str,
# multi-select widget with static options (array of strings)
multi_select_static: list,
# multi-select widget with inputColumns options (array of strings)
multi_select_columns: list
) -> str:
"""
Concatenates all input parameters into a descriptive string.
This demonstrates all UI widget types available in user-defined operators.
"""
lines = [
f"1: Expression (Column Picker) -> {expr_value}",
f"2: Text Input (Single Line) -> {text_input}",
f"3: Text Area (Multi-Line) -> {text_area}",
f"4: Checkbox Option -> {checkbox_flag}",
f"5: Toggle Switch -> {toggle_flag}",
f"6: Number Input -> {number_value}",
f"7: Slider Value -> {slider_value}",
f"8: Select (Static Options) -> {select_static}",
f"9: Select (From Input Columns) -> {select_column}",
f"10: Multi-Select (Static Options) -> [{', '.join(multi_select_static or [])}]",
f"11: Multi-Select (From Input Columns) -> [{', '.join(multi_select_columns or [])}]"
]
return "\n".join(lines)

Teste a função com o seguinte código:

Python
result = concat_all_widgets(
expr_value="column_value_123",
text_input="Hello World",
text_area="Line 1\nLine 2\nLine 3",
checkbox_flag=True,
toggle_flag=False,
number_value=42.5,
slider_value=75.0,
select_static="option_b",
select_column="amount",
multi_select_static=["tag1", "tag3"],
multi_select_columns=["col1", "col3"]
)
print(result)

o passo 2: Criar a configuração YAML

A configuração YAML define como o operador aparece no LakeFlow Designer. Este exemplo demonstra todos os tipos de widgets disponíveis:

YAML
schema: user-defined-operator-v0.1.0
type: uc-udf
name: All Widgets Demo
id: demo.all_widgets
version: '1.0.0'
description: >
A demonstration UDF that showcases all available UI widgets.
config:
type: object
properties:
# ============================================
# EXPRESSION WIDGET
# ============================================
expr_value:
type: string
format: expression
title: 1. Expression (Column Picker)
examples:
- 'Select a column or enter an expression'
x-ui:
widget: expression
port: in

# ============================================
# INPUT WIDGET (single-line text)
# ============================================
text_input:
type: string
title: 2. Text Input (Single Line)
default: default text
examples:
- 'Enter a single line of text'
x-ui:
widget: input

# ============================================
# TEXTAREA WIDGET (multi-line text)
# ============================================
text_area:
type: string
title: 3. Text Area (Multi-Line)
default: Sample text
examples:
- 'Enter multiple lines of text here...'
x-ui:
widget: textarea
rows: 3

# ============================================
# CHECKBOX WIDGET (boolean)
# ============================================
checkbox_flag:
type: boolean
title: 4. Checkbox Option
default: true
x-ui:
widget: checkbox

# ============================================
# TOGGLE WIDGET (boolean switch)
# ============================================
toggle_flag:
type: boolean
title: 5. Toggle Switch
default: false
x-ui:
widget: toggle

# ============================================
# NUMBER WIDGET (numeric input with min/max)
# ============================================
number_value:
type: number
title: 6. Number Input
default: 50
minimum: 0
maximum: 100
examples:
- 'Enter a number (0-100)'
x-ui:
widget: number

# ============================================
# SLIDER WIDGET (numeric slider)
# ============================================
slider_value:
type: number
title: 7. Slider Value
default: 50
minimum: 0
maximum: 100
x-ui:
widget: slider
step: 5

# ============================================
# SELECT WIDGET with STATIC options
# ============================================
select_static:
type: string
title: 8. Select (Static Options)
default: option_a
examples:
- 'Choose an option'
x-ui:
widget: select
optionsSource:
type: static
values:
- option_a
- option_b
- option_c

# ============================================
# SELECT WIDGET with INPUT COLUMNS options
# ============================================
select_column:
type: string
title: 9. Select (From Input Columns)
examples:
- 'Select a column from input'
x-ui:
widget: select
optionsSource:
type: inputColumns
port: in

# ============================================
# MULTI-SELECT WIDGET with STATIC options
# ============================================
multi_select_static:
type: array
items:
type: string
title: 10. Multi-Select (Static Options)
default:
- tag1
- tag2
examples:
- 'Select one or more tags'
x-ui:
widget: multi-select
optionsSource:
type: static
values:
- tag1
- tag2
- tag3
- tag4
- tag5

# ============================================
# MULTI-SELECT WIDGET with INPUT COLUMNS options
# ============================================
multi_select_columns:
type: array
items:
type: string
title: 11. Multi-Select (From Input Columns)
examples:
- 'Select one or more columns'
x-ui:
widget: multi-select
optionsSource:
type: inputColumns
port: in

required:
- expr_value
additionalProperties: false
ports:
input:
- name: in
title: Input Data
output:
- name: out
title: Output

Destaques do esquema

Chave de configuração

Widget

Tipo de dados

Propósito

expr_value

expression

expressão

Selecione uma coluna ou expressão dos dados de entrada.

text_input

input

string

Entrada de texto em uma única linha.

text_area

textarea

string

Entrada de texto em várias linhas.

checkbox_flag

checkbox

Booleana

Caixa de seleção Boolean .

toggle_flag

toggle

Booleana

Interruptor de alternância Boolean .

number_value

number

Número

Entrada numérica com validação de mínimo/máximo.

slider_value

slider

Número

Controle deslizante numérico com incrementos de 0,05.

select_static

select

string

Menu suspenso com opções predefinidas.

select_column

select

string

Lista suspensa preenchida a partir de colunas de entrada.

multi_select_static

multi-select

strings[]

Seleção múltipla com opções predefinidas.

multi_select_columns

multi-select

strings[]

Seleção múltipla preenchida a partir de colunas de entrada.

Opções de tipos de origem

Para widgets select e multi-select , você deve especificar um optionsSource:

Opções estáticas — Lista fixa de valores:

YAML
optionsSource:
type: static
values:
- value1
- value2
- value3

Colunas de entrada — Lista dinâmica de colunas da porta de entrada:

YAML
optionsSource:
type: inputColumns
port: in

Consulte a referência YAML do operador definido pelo usuário para obter um guia completo de todas as propriedades, tipos de dados, widgets e opções disponíveis.

o passo 3: Criar a função Unity Catalog

Combine a configuração YAML e a função Python em uma única instrução CREATE FUNCTION . Observe que os valores string[] (seleção múltipla) são passados como ARRAY<STRING> para a UDF.

SQL
CREATE OR REPLACE FUNCTION main.my_schema.all_widgets_demo(
expr_value STRING,
text_input STRING,
text_area STRING,
checkbox_flag BOOLEAN,
toggle_flag BOOLEAN,
number_value DOUBLE,
slider_value DOUBLE,
select_static STRING,
select_column STRING,
multi_select_static ARRAY<STRING>,
multi_select_columns ARRAY<STRING>
)
RETURNS STRING
LANGUAGE PYTHON
AS $$
"""
schema: user-defined-operator-v0.1.0
type: uc-udf
name: All Widgets Demo
id: demo.all_widgets
version: "1.0.0"
description: >
A demonstration UDF that showcases all available UI widgets.
config:
type: object
properties:
expr_value:
type: string
format: expression
title: 1. Expression (Column Picker)
examples:
- "Select a column or enter an expression"
x-ui:
widget: expression
port: in
text_input:
type: string
title: 2. Text Input (Single Line)
default: "default text"
examples:
- "Enter a single line of text"
x-ui:
widget: input
text_area:
type: string
title: 3. Text Area (Multi-Line)
default: Sample text
examples:
- "Enter multiple lines of text here..."
x-ui:
widget: textarea
rows: 3
checkbox_flag:
type: boolean
title: 4. Checkbox Option
default: true
x-ui:
widget: checkbox
toggle_flag:
type: boolean
title: 5. Toggle Switch
default: false
x-ui:
widget: toggle
number_value:
type: number
title: 6. Number Input
default: 50
minimum: 0
maximum: 100
examples:
- "Enter a number (0-100)"
x-ui:
widget: number
slider_value:
type: number
title: 7. Slider Value
default: 50
minimum: 0
maximum: 100
x-ui:
widget: slider
step: 5
select_static:
type: string
title: 8. Select (Static Options)
default: option_a
examples:
- "Choose an option"
x-ui:
widget: select
optionsSource:
type: static
values:
- option_a
- option_b
- option_c
select_column:
type: string
title: 9. Select (From Input Columns)
examples:
- "Select a column from input"
x-ui:
widget: select
optionsSource:
type: inputColumns
port: in
multi_select_static:
type: array
items:
type: string
title: 10. Multi-Select (Static Options)
default:
- tag1
- tag2
examples:
- "Select one or more tags"
x-ui:
widget: multi-select
optionsSource:
type: static
values:
- tag1
- tag2
- tag3
- tag4
- tag5
multi_select_columns:
type: array
items:
type: string
title: 11. Multi-Select (From Input Columns)
examples:
- "Select one or more columns"
x-ui:
widget: multi-select
optionsSource:
type: inputColumns
port: in
required:
- expr_value
additionalProperties: false
ports:
input:
- name: in
title: Input Data
output:
- name: out
title: Output
"""

def concat_all_widgets(
expr_value: str,
text_input: str,
text_area: str,
checkbox_flag: bool,
toggle_flag: bool,
number_value: float,
slider_value: float,
select_static: str,
select_column: str,
multi_select_static: list,
multi_select_columns: list
) -> str:
lines = [
f"1: Expression (Column Picker) -> {expr_value}",
f"2: Text Input (Single Line) -> {text_input}",
f"3: Text Area (Multi-Line) -> {text_area}",
f"4: Checkbox Option -> {checkbox_flag}",
f"5: Toggle Switch -> {toggle_flag}",
f"6: Number Input -> {number_value}",
f"7: Slider Value -> {slider_value}",
f"8: Select (Static Options) -> {select_static}",
f"9: Select (From Input Columns) -> {select_column}",
f"10: Multi-Select (Static Options) -> [{', '.join(multi_select_static or [])}]",
f"11: Multi-Select (From Input Columns) -> [{', '.join(multi_select_columns or [])}]"
]
return "\n".join(lines)

return concat_all_widgets(
expr_value,
text_input,
text_area,
checkbox_flag,
toggle_flag,
number_value,
slider_value,
select_static,
select_column,
multi_select_static,
multi_select_columns
)
$$

o passo 4: Teste a função

Teste a função UC diretamente com SQL:

SQL
SELECT main.my_schema.all_widgets_demo(
'my_column_value', -- expr_value (expression)
'Hello World', -- text_input (input)
'Multi\nLine\nText', -- text_area (textarea)
TRUE, -- checkbox_flag (checkbox)
FALSE, -- toggle_flag (toggle)
42.5, -- number_value (number)
75.0, -- slider_value (slider)
'option_b', -- select_static (select with static)
'amount', -- select_column (select with inputColumns)
array('tag1', 'tag3'), -- multi_select_static (multi-select with static)
array('col1', 'col2', 'col3') -- multi_select_columns (multi-select with inputColumns)
) AS result;

o passo 5: registrar a operadora

Adicione o operador ao seu arquivo .user_defined_operators.yaml :

YAML
operators:
- catalog: main
schema: my_schema
functionName: all_widgets_demo

o passo 6: Configurar permissões

Conceda acesso aos usuários que precisam usar esta operadora:

SQL
GRANT USE SCHEMA ON SCHEMA main.my_schema TO `<user>`;
GRANT EXECUTE ON FUNCTION main.my_schema.all_widgets_demo TO `<user>`;

Utilizando o operador no LakeFlow Designer

Após o registro, o operador aparecerá no LakeFlow Designer com um painel de configuração completo:

  • Um seletor de expressões para seleção de colunas.
  • Entradas de texto (linha única e várias linhas)
  • Controles Boolean (caixa de seleção e alternância)
  • Entradas numéricas (campo numérico e controle deslizante)
  • menu suspenso com opções estáticas e dinâmicas
  • Controles de seleção múltipla para escolher vários valores.

Este operador serve como uma referência útil para entender como cada tipo de widget renderiza e passa dados para sua função.

Resumo de referência do widget

Widget

Tipo de dados

Opções de interface do usuário

expression

expression

port (obrigatório), placeholder

input

string

placeholder

textarea

string

rows, placeholder

checkbox

boolean

placeholder

toggle

boolean

placeholder

number

number

min, max, placeholder

slider

number

min, max, step, placeholder

select

string

optionsSource (obrigatório), placeholder

multi-select

string[]

optionsSource (obrigatório), placeholder