API এর ওভারভিউ
dscc
(লুকার স্টুডিও কমিউনিটি কম্পোনেন্ট) হল একটি লাইব্রেরি যা লুকার স্টুডিওর জন্য কমিউনিটি কম্পোনেন্ট তৈরিতে সাহায্য করে। সোর্স কোডটি GitHub- এ পাওয়া যাবে।
dscc
তিনটি ফাংশন প্রকাশ করে: getWidth()
, getHeight()
এবং subscribeToData()
।
getWidth()
নাম | পরামিতি | রিটার্ন টাইপ | বর্ণনা |
---|---|---|---|
getWidth() | কোনোটিই নয় | number | পিক্সেলে আইফ্রেমের প্রস্থ ফেরত দেয় |
getWidth()
ব্যবহার করে
// to get the width of the iframe
var width = dscc.getWidth();
getHeight()
নাম | পরামিতি | রিটার্ন টাইপ | বর্ণনা |
---|---|---|---|
প্রাপ্ত উচ্চতা() | কোনোটিই নয় | int | পিক্সেলে আইফ্রেমের উচ্চতা প্রদান করে |
getHeight()
ব্যবহার করে
// to get the height of the iframe
var height = dscc.getHeight();
ইন্টারঅ্যাকশন পাঠান()
sendInteraction()
ফাংশন ফিল্টারের জন্য ডেটা সহ লুকার স্টুডিওতে একটি বার্তা পাঠায়।
পরামিতি:
নাম | টাইপ | বর্ণনা |
---|---|---|
অ্যাকশন আইডি | string | কনফিগারেশনের অ্যাকশনআইডির সাথে সঙ্গতিপূর্ণ স্ট্রিং |
মিথস্ক্রিয়া | enum(InteractionType) | লুকার স্টুডিওকে মিথস্ক্রিয়া সম্পর্কে বলে |
তথ্য | object(InteractionData) | একটি মিথস্ক্রিয়া জন্য প্রয়োজনীয় তথ্য প্রদান করে |
InteractionType
বর্তমানে, একমাত্র বৈধ InteractionType
হল FILTER
।
নাম | টাইপ | বর্ণনা |
---|---|---|
dscc.InteractionType.FILTER | এনাম | FILTER মিথস্ক্রিয়া বর্ণনা করে |
sendInteraction
ব্যবহার করে
// the actionID can either be hardcoded or parsed from the returned data
var actionId = "interactionConfigId";
// dscc provides enums for the interaction types
var FILTER = dscc.InteractionType.FILTER;
var fieldID = "qt_m9dtntutsb";
var dataValue = "Asia";
// sendInteraction expects data that tells you the concepts and the values of
// those concepts to use in constructing a filter.
var interactionData = {
"concepts": [fieldId],
"values": [[dataValue]]
}
dscc.sendInteraction(actionId, FILTER, interactionData);
interactionData
var interactionData = {
"concepts": array(fieldId),
"values": array(array(dataValue))
}
মাঠ | টাইপ | বর্ণনা |
---|---|---|
ধারণা | Array | fieldIds অ্যারে |
মান | Array<Array> | ডেটা মানের নেস্টেড অ্যারে। প্রতিটি সাবঅ্যারে concepts অ্যারের দৈর্ঘ্য হওয়া উচিত। সাবয়ারের প্রতিটি মান একটি মাত্রা মানের সাথে মিলে যায়। |
নমুনা interactionData
:
var interactionData = {
"concepts": ["dim1Id", "dim2Id"],
"values": [
["dim1Val1", "dim2Val1"],
["dim1Val2", "dim2Val2"]
]
}
উপরের interactionData
সাথে dscc.sendInteraction
ব্যবহার করা নিম্নলিখিত SQL স্টেটমেন্টের সমতুল্য:
SELECT data WHERE
(dim1 == dim1Val1 AND dim2 == dim2Val1)
OR
(dim1 == dim1Val2 AND dim2 == dim2Val2);
স্পষ্ট মিথস্ক্রিয়া()
clearInteraction()
ফাংশন লুকার স্টুডিওতে একটি বার্তা পাঠায় যাতে এই ভিজ্যুয়ালাইজেশন দ্বারা পূর্বে সেট করা একটি ফিল্টার সাফ করা হয়।
পরামিতি:
নাম | টাইপ | বর্ণনা |
---|---|---|
অ্যাকশন আইডি | string | কনফিগারেশনের অ্যাকশনআইডির সাথে সঙ্গতিপূর্ণ স্ট্রিং |
মিথস্ক্রিয়া | enum(InteractionType) | লুকার স্টুডিওকে মিথস্ক্রিয়া সম্পর্কে বলে |
clearInteraction()
// the actionID can either be hardcoded or parsed from the returned data
var actionId = "interactionConfigId";
// dscc provides enums for the interaction types
var FILTER = dscc.InteractionType.FILTER;
dscc.clearInteraction(actionId, FILTER);
subscribeToData(callback, options)
subscribeToData()
ফাংশন লুকার স্টুডিও থেকে বার্তা সাবস্ক্রাইব করে।
পরামিতি:
নাম | টাইপ | বর্ণনা |
---|---|---|
কলব্যাক(ডেটা) | function | একটি ফাংশন যা subscribeToData দ্বারা ফেরত ডেটা নেয়। |
বিকল্প | object | পছন্দসই ডেটা রিটার্ন বিন্যাস সংজ্ঞায়িত করে |
অপশন অবজেক্ট এর মত দেখাচ্ছে:
{
transform: dscc.tableTransform | dscc.objectTransform
}
রিটার্ন মান:
টাইপ | বর্ণনা |
---|---|
function | Looker Studio থেকে আরও বার্তা থেকে callback ত্যাগ করে |
subscribeToData()
ব্যবহার করে
// define and use a callback
var unsubscribe = dscc.subscribeToData(function(data){
// console.log the returned data
console.log(data);
}, {transform: dscc.tableTransform});
// to unsubscribe
unsubscribe();
data
এটি dscc.subscribeToData
এর সাথে নিবন্ধিত callback
পাস করা বস্তু। নিম্নলিখিত ক্ষেত্রগুলি dscc.objectFormat
এবং dscc.tableFormat
এর মধ্যে ভাগ করা হয়েছে।
{
fields: object(fieldsByConfigId),
style: object(styleById),
interactions: object(interactionsById),
theme: object(themeStyle),
tables: object(tablesById),
dateRanges: object(dateRangesById)
}
মাঠ | টাইপ | বর্ণনা |
---|---|---|
ক্ষেত্র | object(fieldsByConfigId) | একটি অবজেক্ট যা তাদের configId দ্বারা সূচীকৃত ক্ষেত্র ধারণ করে |
শৈলী | object(styleById) | একটি অবজেক্ট যা তাদের কনফিগার আইডি দ্বারা সূচীকৃত স্টাইল অবজেক্ট ধারণ করে |
মিথস্ক্রিয়া | object(interactionsById) | একটি বস্তু যা মিথস্ক্রিয়া বস্তু ধারণ করে |
থিম | themeStyle | একটি থিমস্টাইল অবজেক্ট যাতে রিপোর্টের জন্য থিম স্টাইলিং তথ্য থাকে |
টেবিল | object(tablesById) | টেবিল অবজেক্ট ধারণ করে এমন একটি বস্তু |
তারিখ রেঞ্জ | object(dateRangesById) | তারিখরেঞ্জ ধারণ করে এমন একটি বস্তু |
fieldsByConfigId
{
configId: array(field)
}
fieldsByConfigId
অবজেক্টে ভিজ্যুয়ালাইজেশন কনফিগারেশনে সংজ্ঞায়িত "id" দ্বারা সূচীকৃত ফিল্ড অবজেক্টের অ্যারে রয়েছে। কনফিগারেশনে সংজ্ঞায়িত প্রতিটি dataField
জন্য এই অবজেক্টে একটি এন্ট্রি রয়েছে।
মাঠ | টাইপ | বর্ণনা |
---|---|---|
কনফিগার আইডি | Array<field> | ডেটাফিল্ডের সাথে যুক্ত ক্ষেত্র(গুলি) এর একটি অ্যারে |
ক্ষেত্র
{
id: fieldId,
name: string,
description: string,
type: fieldType,
concept: enum(conceptType)
}
field
অবজেক্টটি ক্ষেত্র সম্পর্কে তথ্য প্রদান করে যা ব্যবহারকারী সম্পত্তি প্যানেলে নির্বাচন করে।
মাঠ | টাইপ | বর্ণনা |
---|---|---|
আইডি | string | লুকার স্টুডিও ক্ষেত্রের জন্য আইডি তৈরি করেছে |
নাম | string | মানুষের-পাঠযোগ্য ক্ষেত্রের নাম |
বর্ণনা | string | মাঠের বর্ণনা |
টাইপ | enum(fieldType) | ক্ষেত্রের শব্দার্থিক প্রকার |
ধারণা | enum(conceptType) | ক্ষেত্রের ধারণার ধরন |
styleById
{
configId: styleValue
}
styleById
অবজেক্ট ভিজ্যুয়ালাইজেশন কনফিগারেশনে সংজ্ঞায়িত "id" দ্বারা সূচীকৃত শৈলী তথ্য প্রদান করে।
মাঠ | টাইপ | বর্ণনা |
---|---|---|
কনফিগার আইডি | styleValue | একটি বস্তু যাতে শৈলী মান এবং কনফিগার-সংজ্ঞায়িত ডিফল্ট শৈলী মান রয়েছে |
শৈলী মান
{
value: string | object | bool | number,
defaultValue: string | object | bool | number
}
styleValue
অবজেক্ট ব্যবহারকারীর দ্বারা নির্বাচিত শৈলী মান এবং কনফিগারে সংজ্ঞায়িত ডিফল্ট মান উভয়ই প্রদান করে। value
এবং defaultValue
ধরন শৈলী উপাদানের উপর নির্ভর করে।
মাঠ | টাইপ | বর্ণনা |
---|---|---|
মান | string OR object OR bool OR number | প্রপার্টি প্যানেলে ব্যবহারকারী নির্বাচন থেকে ফিরে আসা শৈলী উপাদানের মান |
ডিফল্ট মান | string OR object OR bool OR number | ভিজ্যুয়ালাইজেশন কনফিগারেশনে সংজ্ঞায়িত শৈলী উপাদানের ডিফল্ট মান |
মিথস্ক্রিয়া দ্বারা আইডি
{
}
interactionsById
অবজেক্ট ইন্টারঅ্যাকশন interactionId
ভিজ্যুয়ালাইজেশন কনফিগারেশন দ্বারা ইন্ডেক্স করা ইন্টারঅ্যাকশন ডেটা প্রদান করে।
সূচক | টাইপ | বর্ণনা |
---|---|---|
কনফিগার আইডি | interaction | একটি বস্তু যা একটি মিথস্ক্রিয়া সম্পর্কিত ডেটা ধারণ করে |
মিথস্ক্রিয়াক্ষেত্র
{
value: object(interactionValue),
supportedActions: array(InteractionType)
}
interactionField
অবজেক্টে কনফিগারেশনে সংজ্ঞায়িত সমর্থিত অ্যাকশনের অ্যারে রয়েছে, সেইসাথে ইন্টারঅ্যাকশনের জন্য ব্যবহারকারী-নির্বাচিত মান রয়েছে।
মাঠ | টাইপ | বর্ণনা |
---|---|---|
মান | string OR object OR bool OR number | প্রপার্টি প্যানেলে ব্যবহারকারী নির্বাচন থেকে ফিরে আসা শৈলী উপাদানের মান |
সমর্থিত কর্ম | Array<InteractionType> | এই মিথস্ক্রিয়া দ্বারা সমর্থিত কর্ম, কনফিগারে সংজ্ঞায়িত করা হয়েছে |
ইন্টারঅ্যাকশন ভ্যালু
interactionValue
ভ্যালু অবজেক্ট ইন্টারঅ্যাকশন প্রকারের জন্য ব্যবহারকারী-নির্বাচিত মান প্রদান করে। data
কী বিদ্যমান থাকলে, InteractionData
অবজেক্ট ফিল্টারের বর্তমান অবস্থা প্রতিফলিত করে। যদি data
কী বিদ্যমান না থাকে, ভিজ্যুয়ালাইজেশন বর্তমানে একটি ফিল্টার হিসাবে কনফিগার করা হয় না।
{
type: enum(InteractionType)
data: object(interactionData) | None
}
মাঠ | টাইপ | বর্ণনা |
---|---|---|
টাইপ | enum(InteractionType) | ব্যবহারকারী-নির্বাচিত ইন্টারঅ্যাকশন টাইপ |
তথ্য | object(InteractionData) | ফিল্টারের বর্তমান অবস্থার সাথে সম্পর্কিত ডেটা । ফিল্টারটি বর্তমানে সাফ করা হলে এই কীটি বিদ্যমান নেই। |
থিম
{
fillColor: {
color: string,
opacity: number
},
fontColor: {
color: string,
opacity: number
},
accentFillColor: {
color: string,
opacity: number
},
accentFontColor: {
color: string,
opacity: number
},
fontFamily: string,
accentFontFamily: string,
increaseColor: {
color: string,
opacity: number
},
decreaseColor: {
color: string,
opacity: number
},
gridColor: {
color: string,
opacity: number
},
seriesColor: [
{
color: string,
opacity: number
}
]
}
themeStyle
অবজেক্ট ভিজ্যুয়ালাইজেশনে রিপোর্ট থিম তথ্য পাস করে।
মাঠ | টাইপ | বর্ণনা |
---|---|---|
fillColor | object | বিন্যাসের একটি বস্তু {color: string, opacity: number} |
ফন্ট কালার | object | বিন্যাসের একটি বস্তু {color: string, opacity: number} |
accentFillColor | object | বিন্যাসের একটি বস্তু {color: string, opacity: number} |
অ্যাকসেন্ট ফন্ট কালার | object | বিন্যাসের একটি বস্তু {color: string, opacity: number} |
ফন্ট ফ্যামিলি | string | ফন্ট পরিবার বর্ণনা করে একটি স্ট্রিং |
accentFontFamily | string | অ্যাকসেন্ট ফন্ট পরিবার বর্ণনা করে একটি স্ট্রিং |
রঙ বৃদ্ধি | object | বিন্যাসের একটি বস্তু {color: string, opacity: number} |
রঙ হ্রাস | object | বিন্যাসের একটি বস্তু {color: string, opacity: number} |
গ্রিড রঙ | object | বিন্যাসের একটি বস্তু {color: string, opacity: number} |
সিরিজের রঙ | Array<object> | বিন্যাসের বস্তুর একটি অ্যারে {color: string, opacity: number} |
টেবিল দ্বারা আইডি
{
"DEFAULT": object(tableObject),
"COMPARISON": object(tableObject) | undefined
}
tableObject
প্রতিটি সারির জন্য শিরোনাম এবং ডেটা তথ্য সরবরাহ করে। "ডিফল্ট" সর্বদা ডেটা প্রদান করবে, এবং "তুলনা" শুধুমাত্র তখনই পপুলেট করা হবে যদি ব্যবহারকারী তুলনা সারিগুলির সাথে ডেটা কনফিগার করে।
tableObject-এর বিন্যাস হল dscc.tableFormat
এবং dscc.objectFormat
এর মধ্যে পার্থক্য।
মাঠ | টাইপ | বর্ণনা |
---|---|---|
"ডিফল্ট" | object(tableObject) OR Array<objectRow> | একজন ব্যবহারকারী ভিজ্যুয়ালাইজেশনে যোগ করে এমন ডেটার সাথে যুক্ত tableObject |
"তুলনা" | object(tableObject) OR Array<objectRow> | প্রযোজ্য হলে তারিখ তুলনা ডেটার সাথে যুক্ত tableObject |
তারিখ রেঞ্জসবাই আইডি
{
"DEFAULT": object(dateRange),
"COMPARISON": object(dateRange)
}
dateRangesById
অবজেক্ট ডিফল্ট এবং তুলনা তারিখ ব্যাপ্তি সম্পর্কে তথ্য প্রদান করে। যদি কোনো তারিখ ব্যাপ্তি না থাকে, তাহলে বস্তুটি খালি থাকবে। DEFAULT
এবং COMPARISON
শুধুমাত্র তখনই পপুলেট করা হবে যদি সংশ্লিষ্ট তারিখ ব্যাপ্তি ব্যবহারকারীর দ্বারা কনফিগার করা হয়। তারিখ ব্যাপ্তির ডেটা ডিফল্ট এবং তুলনা ডেটার সাথে সম্পর্কিত যা tablesById এ সংজ্ঞায়িত করা হয়েছে।
মাঠ | টাইপ | বর্ণনা |
---|---|---|
"ডিফল্ট" | object(dateRange) | dateRange ডিফল্ট তারিখ ব্যাপ্তির সাথে যুক্ত, যদি প্রযোজ্য হয়। |
"তুলনা" | object(dateRange) | dateRange তুলনামূলক তারিখ ব্যাপ্তির সাথে যুক্ত, যদি প্রযোজ্য হয়। |
তারিখ পরিসীমা
{
start: string,
end: string
}
dateRange
অবজেক্ট একটি ডিফল্ট বা তুলনা তারিখ সীমার শুরু এবং শেষ তারিখ সম্পর্কে তথ্য প্রদান করে।
মাঠ | টাইপ | বর্ণনা |
---|---|---|
শুরু | string | YYYYMMDD ফর্ম্যাটে তারিখ ব্যাপ্তির শুরুর তারিখ। |
শেষ | string | YYYYMMDD ফর্ম্যাটে তারিখ ব্যাপ্তির শেষ তারিখ। |
tableFormat
রেফারেন্স
টেবিল অবজেক্ট
{
headers: array(object),
rows: array(array)
}
মাঠ | টাইপ | বর্ণনা |
---|---|---|
হেডার | Array | ক্ষেত্র বস্তুর একটি অ্যারে. এই ফিল্ড অবজেক্টগুলির অতিরিক্ত একটি configId বৈশিষ্ট্য রয়েছে যা কনফিগার থেকে আইডিগুলির সাথে মিলে যায়। |
সারি | Array<Array> | অ্যারের অ্যারে: প্রতিটি অ্যারে ডেটার একটি সারি |
নমুনা tableFormat
ডেটা
এটি dscc.tableFormat
বিকল্পের সাথে dscc.subscribeToData()
ব্যবহার করে ফেরত দেওয়া নমুনা data
।
{
"tables": {
"DEFAULT": {
"headers": [{
"id": "qt_ky8sltutsb",
"name": "dimension",
"type": "TEXT",
"concept": "DIMENSION",
"configId": "configId1"
}, {
"id": "qt_b5bvmtutsb",
"name": "second dim",
"type": "TEXT",
"concept": "DIMENSION"
"configId": "configId1"
}, {
"id": "qt_m9dtntutsb",
"name": "metric",
"type": "NUMBER",
"concept": "METRIC",
"configId": "configId2"
}],
"rows": [
["Week 4", "lm", 55]
]
},
"COMPARISON": {
"headers": [{
"id": "qt_ky8sltutsb",
"name": "dimension",
"type": "TEXT",
"concept": "DIMENSION",
"configId": "configId1"
}, {
"id": "qt_b5bvmtutsb",
"name": "second dim",
"type": "TEXT",
"concept": "DIMENSION"
"configId": "configId1"
}, {
"id": "qt_m9dtntutsb",
"name": "metric",
"type": "NUMBER",
"concept": "METRIC",
"configId": "configId2"
}],
"rows": [
["Week 5", "no", 123]
]
}
},
"fields": {
"configId1": [
{
"id": "qt_ky8sltutsb",
"name": "week",
"type": "TEXT",
"concept": "DIMENSION"
},
{
"id": "qt_b5bvmtutsb",
"name": "textId",
"type": "TEXT",
"concept": "DIMENSION"
}
],
"configId2": [
{
"id": "qt_m9dtntutsb",
"name": "orders",
"type": "NUMBER",
"concept": "METRIC"
}
]
},
"style": {
"nodeColor": {
"value": {
"color": "#000000"
}
}
},
"theme": {},
"dateRanges": {
"DEFAULT": {
"start": "20210501",
"end": "20210531"
},
"COMPARISON": {
"start": "20200501",
"end": "20200531"
}
},
"interactions": {
"onClick": {
"value": {
"type": "FILTER",
"data": {
"concepts": [
"qt_h6oibrb6wb",
"qt_i6oibrb6wb"
],
"values": [
[
"Afternoon",
"Sunday"
],
[
"Afternoon",
"Thursday"
],
[
"Morning",
"Tuesday"
]
]
}
},
"supportedActions": [
"FILTER"
]
}
}
}
অবজেক্ট ফরম্যাট রেফারেন্স
অবজেক্টরো
{
configId1: array(string | bool | number),
configId2: array(string | bool | number)
}
মাঠ | টাইপ | বর্ণনা |
---|---|---|
কনফিগার আইডি | অ্যারে | একটি নির্দিষ্ট কনফিগার আইডির সাথে যুক্ত মানগুলির অ্যারে |
নমুনা অবজেক্ট ফরম্যাট ডেটা
এটি dscc.objectFormat
বিকল্পের সাথে dscc.subscribeToData()
ব্যবহার করে ফেরত দেওয়া নমুনা data
।
{
"tables": {
"COMPARISON": [
{
"configId1": ["Week 5", "cd"],
"configId2": [123]
}
],
"DEFAULT": [
{
"configId1": ["Week 1", "ab"],
"configId2": [24]
}
]
},
"fields": {
"configId1": [
{
"id": "qt_h6oibrb6wb",
"name": "time of day",
"type": "TEXT",
"concept": "DIMENSION"
},
{
"id": "qt_i6oibrb6wb",
"name": "day",
"type": "TEXT",
"concept": "DIMENSION"
}
],
"configId2": [
{
"id": "qt_m9dtntutsb",
"name": "metric",
"type": "NUMBER",
"concept": "METRIC"
}
]
},
"style": {
"nodeColor": {
"value": {
"color": "#000000"
}
}
},
"theme": {},
"dateRanges": {
"DEFAULT": {
"start": "20210501",
"end": "20210531"
},
"COMPARISON": {
"start": "20200501",
"end": "20200531"
}
},
"interactions": {
"onClick": {
"value": {
"type": "FILTER",
"data": {
"concepts": [
"qt_h6oibrb6wb",
"qt_i6oibrb6wb"
],
"values": [
[
"Afternoon",
"Sunday"
],
[
"Afternoon",
"Thursday"
],
[
"Morning",
"Tuesday"
]
]
}
},
"supportedActions": [
"FILTER"
]
}
}
}