AppAPI వినియోగదారులకు FormEngine మరియు DMView లో వివిధ పద్ధతులను ఉపయోగించి యాప్ నుండి సిస్టమ్ మెటా డేటా లోడ్ చేయడానికి అనుమతిస్తుంది. యాప్ నుండి నిర్దిష్ట సమాచారం పొందడానికి వివిధ డేటా కీలను యాక్సెస్ చేయడానికి ఇది అనుమతిస్తుంది.

xlsform లో, మీరు pulldata() ఫంక్షన్‌ను కింది సింటాక్స్‌తో ఉపయోగించవచ్చు:

  • 'app-api': ఈ కీవర్డ్ FormEngine కి App API నుండి డేటా లోడ్ చేయమని తెలియజేస్తుంది.
  • 'data-key': మీరు App API నుండి లోడ్ చేయాలనుకున్న డేటా యొక్క కీ ఇది.
  • డేటా కీ చెల్లుబాటు కాకపోతే లేదా మద్దతు లేకపోతే, లెక్కింపు “n/a” అని తిరిగి ఇస్తుంది.

App-API తో ఉపయోగించగల మద్దతు ఉన్న డేటా కీలు ఇక్కడ ఉన్నాయి:

osPlatform: ప్రస్తుత OS పేరు (Android లేదా iOS) మరియు OS వెర్షన్ తిరిగి ఇస్తుంది. వెబ్ ప్లాట్‌ఫారమ్‌లు ఖాళీ విలువ తిరిగి ఇస్తాయి.

appPlatform: యాప్ ప్లాట్‌ఫారమ్ పేరు తిరిగి ఇస్తుంది, ఇది rtSurvey.

appVersion: యాప్ వెర్షన్ పేరు తిరిగి ఇస్తుంది.

getDisplayWidth: పరికర స్క్రీన్ వెడల్పు పిక్సెల్‌లలో తిరిగి ఇస్తుంది.

getDisplayHeight: పరికర స్క్రీన్ ఎత్తు పిక్సెల్‌లలో తిరిగి ఇస్తుంది.

getScreenSize: పరికర స్క్రీన్ పరిమాణం అంగుళాలలో తిరిగి ఇస్తుంది.

projectCode: వినియోగదారుడు సైన్ ఇన్ చేస్తున్న సైట్ యొక్క ప్రస్తుత ప్రాజెక్ట్ కోడ్ తిరిగి ఇస్తుంది.

projectURL: వినియోగదారుడు సైన్ ఇన్ చేస్తున్న సైట్ యొక్క ప్రస్తుత ప్రాజెక్ట్ URL తిరిగి ఇస్తుంది. డిఫాల్ట్/ఫాల్‌బ్యాక్ విలువ ఖాళీ టెక్స్ట్ ("").

startingPoint: ఫారం ప్రారంభించే పాయింట్ యొక్క మార్గం తిరిగి ఇస్తుంది. మరిన్ని వివరాలకు “Form starting point” చూడండి.

serverTime: సర్వర్‌లో తేది మరియు సమయం యొక్క ఉత్తమంగా అందుబాటులో ఉన్న అంచనా తిరిగి ఇస్తుంది.

user.[attribute]: నిర్దేశించిన attribute కీ ఆధారంగా ప్రస్తుత వినియోగదారు attributes తిరిగి ఇస్తుంది. అందుబాటులో ఉన్న attribute కీలకు “User attributes” పట్టిక చూడండి.

ప్రస్తుత వినియోగదారు సమాచారం పొందడానికి pulldata() params లో “user.” తో కింది attribute కీలు కలపండి. ఉదాహరణకు, user.username, user.email మొదలైనవి ఉపయోగించండి.

Attribute Keyవివరణ
usernameవినియోగదారు యొక్క వినియోగదారుపేరు
nameవినియోగదారు యొక్క పూర్తి పేరు
staffCodeవినియోగదారు యొక్క స్టాఫ్ కోడ్
phoneవినియోగదారు యొక్క ఫోన్ నంబర్
emailవినియోగదారు యొక్క ఇమెయిల్ చిరునామా
descriptionవినియోగదారు సమాచారంలో వివరణ టెక్స్ట్
organization_idవినియోగదారుడు చెందిన సంస్థ ID
organization_nameవినియోగదారుడు చెందిన సంస్థ పేరు
team_idవినియోగదారుడు చెందిన టీమ్ ID
supervisor_idవినియోగదారు సూపర్‌వైజర్ యొక్క ID
is_supervisorవినియోగదారుడు సూపర్‌వైజర్ అయితే 1, కాకపోతే 0

instancePath: ప్రస్తుత ఇన్‌స్టెన్స్ ఫోల్డర్ మార్గం తిరిగి ఇస్తుంది.

appLanguage: యాప్ సెట్టింగులలో సెట్ చేయబడిన ప్రస్తుత యాప్ భాష తిరిగి ఇస్తుంది (ఉదా. vi, en).

openArgs.[attribute]: ActionButton (act_fill_form, act_get_instance) నుండి పాస్ చేయబడిన open-form-argument తిరిగి ఇస్తుంది. డిఫాల్ట్/ఫాల్‌బ్యాక్ విలువ ఖాళీ టెక్స్ట్ ("").

primaryAppColor: యాప్ యొక్క ప్రాథమిక రంగు తిరిగి ఇస్తుంది.


వినియోగ ఉదాహరణలు

గణికుని వినియోగదారు పేరు మరియు సంస్థ నిల్వ చేయడం

typenamelabelcalculation
calculateenumerator_namepulldata('app-api', 'user.name')
calculateenumerator_orgpulldata('app-api', 'user.organization_name')
calculateenumerator_emailpulldata('app-api', 'user.email')

ఆడిట్ ప్రయోజనాల కోసం నోట్ లేబుళ్ళలో వీటిని ఉపయోగించండి:

  note | interviewer_info | Interviewer: ${enumerator_name} (${enumerator_org})
  

పరికరం మరియు స్క్రీన్ సమాచారం

typenamelabelcalculation
calculatedevice_platformpulldata('app-api', 'osPlatform')
calculateapp_verpulldata('app-api', 'appVersion')
calculatescreen_wpulldata('app-api', 'getDisplayWidth')

నివారణకు ఉపయోగకరం: ప్రతి సమర్పణకు ఏ పరికర వెర్షన్ ఉపయోగించబడిందో గుర్తించడానికి మీ డేటాతో పాటు device_platform మరియు app_ver ఎగుమతి చేయండి.

పరికర సమయం బదులు సర్వర్ సమయం

పరికర గడియారాలు తప్పు కావచ్చు. మరింత నమ్మదగిన టైమ్‌స్టాంప్ కోసం serverTime ఉపయోగించండి:

typenamelabelcalculation
calculateserver_tspulldata('app-api', 'serverTime')

వినియోగదారు పాత్ర ఆధారంగా షరతులతో కూడిన లాజిక్

సూపర్‌వైజర్‌లకు మాత్రమే సూపర్‌వైజర్ విభాగం చూపించండి:

typenamelabelrelevant
calculateis_supervisorpulldata('app-api', 'user.is_supervisor')
begin_groupsupervisor_sectionSupervisor review${is_supervisor} = '1'
textsupervisor_notesSupervisor notes
end_group

యాక్షన్ బటన్ నుండి arguments పాస్ చేయడం

ఫారం అనుకూల arguments తో act_fill_form యాక్షన్ బటన్ నుండి ప్రారంభించబడినప్పుడు:

typenamelabelcalculation
calculatepassed_hh_idpulldata('app-api', 'openArgs.household_id')
calculatepassed_taskpulldata('app-api', 'openArgs.task_code')

యాక్షన్ బటన్ సరిపోలే కీలతో arguments పాస్ చేయాలి (ఉదా. household_id, task_code).

ప్రాజెక్ట్ సమాచారం ఉపయోగించడం

typenamelabelcalculation
calculateprojectpulldata('app-api', 'projectCode')
calculateproject_urlpulldata('app-api', 'projectURL')

గమనికలు

  • అన్ని pulldata('app-api', ...) కాల్‌లు ఫారం తెరిచినప్పుడు మూల్యాంకనం చేయబడతాయి మరియు సెషన్ సమయంలో డైనమిక్‌గా తిరిగి మూల్యాంకనం చేయబడవు (serverTime మరియు now() మినహా).
  • ఒక కీ మద్దతు లేకపోతే లేదా డేటా అందుబాటులో లేకపోతే, ఫంక్షన్ 'n/a' తిరిగి ఇస్తుంది (ఖాళీ స్ట్రింగ్ కాదు — != '' బదులు != 'n/a' తో పరీక్షించండి).
  • openArgs విలువలు ఫారం యాక్షన్ బటన్ నుండి ప్రారంభించబడినప్పుడు మాత్రమే అందుబాటులో ఉంటాయి; లేకపోతే అవి ఖాళీ స్ట్రింగ్ తిరిగి ఇస్తాయి.
ఈ పేజీ సహాయకరంగా ఉందా?