پیکربندی مرحلهای به یک رابط اجازه میدهد تا به صورت پویا پیکربندی کانکتور را بر اساس پاسخهای ارائهشده توسط کاربر پر کند. به عنوان مثال، پر کردن یک منوی کرکرهای «شهر» پس از انتخاب فهرست کشویی «ایالت».
الزامات
این راهنما فرض می کند که شما قبلاً با پیکربندی های Connector Community آشنا هستید. برای بازنگری به تعریف پیکربندی از طریق getConfig مراجعه کنید.
نمای کلی
پیکربندی مرحلهای شامل استودیو Looker است که چندین بار getConfig()
را فراخوانی میکند و رابط شما هر بار سؤالات پیکربندی بیشتری را برمیگرداند. هر تماس با getConfig()
شامل پاسخ های کاربر به آخرین پاسخ getConfig()
می شود. این فرآیند تا زمانی ادامه می یابد که شما یک پاسخ را با setIsSteppedConfig(true)
برگردانید.
رهنمودها
-
setIsSteppedConfig(true)
را تنظیم کنید تا پیکربندی کامل شود - تا زمانی که
setIsSteppedConfig(true)
تنظیم شده باشد، Looker Studio مکرراًgetConfig()
فراخوانی می کند. پس از تکمیل پیکربندی، پاسخgetConfig()
نهایی بایدsetIsSteppedConfig(false)
را تنظیم کند. - برای سؤالات پیکربندی که سؤالات بعدی را تعیین می کنند،
isDynamic(true)
را تنظیم کنید - اگر فیلدی با علامت
isDynamic
توسط کاربر اصلاح شود، ورودیهای پیکربندی بعدی در UI پاک میشوند و کاربر باید تمام مراحل بعدی را پیکربندی کند. این کمک می کند مطمئن شوید که کاربران پیکربندی نامعتبر را برای شما ارسال نمی کنند. - پاسخ های ارائه شده توسط کاربر از طریق
request.configParams
ارسال می شود. request.configParams
برای اولین درخواستgetConfig()
به کانکتور شماundefined
است. درخواستهای بعدی شامل پاسخهای ارائهشده توسط کاربر بهعنوان یک شی کلیددار شده توسط شناسههای پیکربندی یاundefined
در صورتی که کاربر هیچ پاسخی ارائه نکرد، خواهد بود.مثال:
{ state: 'CA', city: 'mountain_view' }
- پیکربندی ها افزودنی هستند
سؤالات پیکربندی جدید باید بعد از سؤالات موجود اضافه شوند.
- تنظیمات را نمی توان تغییر داد
اگر قبلاً سؤال پیکربندی پرسیده شده است، باید برای همه تماسهای بعدی وجود داشته باشد. برای مثال، اگر سوال پیکربندی A در اولین فراخوانی
getConfig()
پرسیده شد، A باید در تمام پاسخهای آینده گنجانده شود.- پیکربندی ها بی قدرت هستند
فراخوانی های
getConfig()
با همانconfigParams
باید همان پیکربندی را برگردانند.- پارامترهای پویا را نمی توان نادیده گرفت
Looker Studio اجازه نمی دهد که پارامترهای پیکربندی پویا لغو شوند.
تنظیمات نمونه
کشویی پویا
این سوال اول کاربر را وادار می کند تا یک ایالت را انتخاب کند، سپس به صورت پویا یک فهرست کشویی شهر را بر اساس ایالت انتخاب شده ارائه می دهد.
var cc = DataStudioApp.createCommunityConnector();
function optionsForState(state) {
switch (state) {
case "IL": {
return [["Chicago", "chicago"], ["Springfield", "springfield"]];
}
case "CA": {
return [["Mountain View", "mountain_view"], ["Los Angeles", "los_angeles"]];
}
default: {
cc.newUserError()
.setText('You must either select "IL" or "CA"')
.throwException();
}
}
}
function getConfig(request) {
var configParams = request.configParams;
var isFirstRequest = configParams === undefined;
var config = cc.getConfig();
if (isFirstRequest) {
config.setIsSteppedConfig(true);
}
config.newSelectSingle()
.setId("state")
.setName("State")
// Set isDynamic to true so any changes to State will clear the city
// selections.
.setIsDynamic(true)
.addOption(config.newOptionBuilder().setLabel("Illinois").setValue("IL"))
.addOption(config.newOptionBuilder().setLabel("California").setValue("CA"));
if (!isFirstRequest) {
var city = config.newSelectSingle()
.setId("city")
.setName("City");
var cityOptions = optionsForState(configParams.state);
cityOptions.forEach(function(labelAndValue) {
var cityLabel = labelAndValue[0];
var cityValue = labelAndValue[1];
city.addOption(config.newOptionBuilder().setLabel(cityLabel).setValue(cityValue));
});
}
return config.build();
}
مسیرهای انشعاب
اگر "کشور" انتخاب شده "ایالات متحده آمریکا" باشد، این یک سوال اضافی خواهد پرسید.
var cc = DataStudioApp.createCommunityConnector();
function getConfig(request) {
var configParams = request.configParams;
var isFirstRequest = configParams === undefined;
var config = cc.getConfig();
if (isFirstRequest) {
config.setIsSteppedConfig(true);
}
config
.newSelectSingle()
.setId('country')
.setName('Country')
// Set isDynamic to true so any changes to Country will clear the state
// selections.
.setIsDynamic(true)
.addOption(config.newOptionBuilder().setLabel('United States').setValue('USA'))
.addOption(config.newOptionBuilder().setLabel('Canada').setValue('CA'));
if (!isFirstRequest) {
// validate a valid value was selected for configParams.country
if (configParams.country === undefined) {
cc.newUserError().setText('You must choose a country.').throwException();
}
switch (configParams.country) {
case 'USA': {
config
.newSelectSingle()
.setId('state')
.setName('State')
.addOption(config.newOptionBuilder().setLabel('New York').setValue('NY'))
.addOption(config.newOptionBuilder().setLabel('Calfornia').setValue('CA'));
break;
}
case 'CA': {
// No additional configuration is needed for Canada.
break;
}
default: {
cc.newUserError()
.setText('You must either select "CA" or "USA"')
.throwException();
}
}
}
return config.build();
}