如何在自定义 Zapier 应用程序中从 Xero 访问特定订单项值?

Posted

技术标签:

【中文标题】如何在自定义 Zapier 应用程序中从 Xero 访问特定订单项值?【英文标题】:How to access specific line item value from Xero in a custom Zapier app? 【发布时间】:2021-07-30 00:59:26 【问题描述】:

我正在构建一个自定义 Zapier 应用程序,需要通过 Xero API 获取特定的嵌套值。

我的 API 端点是这样设置的:

const options = 
  url: `https://api.xero.com/api.xro/2.0/Contacts/$bundle.inputData.ContactID`,
  method: 'GET',
  headers: 
    'Content-Type': 'application/json',
    'Accept': 'application/json',
    'Authorization': `Bearer $bundle.authData.access_token`,
    'xero-tenant-id': process.env.TENANT_ID
  ,



return z.request(options)
  .then((response) => 
    response.throwForStatus();
    const results = response.json;



    return results;
  );

这是返回:

  "Id": "8092d924-6ce1-415e-9a45-f61294c17bc7",
  "Status": "OK",
  "ProviderName": "Commission statements",
  "DateTimeUTC": "/Date(1620408485950)/",
  "Contacts": [
    
      "ContactID": "fd9c3e88-4128-4d68-94f6-d40eef08d3b2",
      "AccountNumber": "1846",
      "ContactStatus": "ACTIVE",
      "Name": "xxx",
      "FirstName": "",
      "LastName": "",
      "EmailAddress": "xxx@test.com",
      "BankAccountDetails": "",
      "Addresses": [
        
          "AddressType": "STREET",
          "City": "",
          "Region": "",
          "PostalCode": "",
          "Country": "",
          "AttentionTo": ""
        ,
        
          "AddressType": "POBOX",
          "City": "",
          "Region": "",
          "PostalCode": "",
          "Country": "",
          "AttentionTo": ""
        
      ],
      "Phones": [
        
          "PhoneType": "DDI",
          "PhoneNumber": "",
          "PhoneAreaCode": "",
          "PhoneCountryCode": ""
        ,
        
          "PhoneType": "DEFAULT",
          "PhoneNumber": "",
          "PhoneAreaCode": "",
          "PhoneCountryCode": ""
        ,
        
          "PhoneType": "FAX",
          "PhoneNumber": "0014I000023R123",
          "PhoneAreaCode": "",
          "PhoneCountryCode": ""
        ,
        
          "PhoneType": "MOBILE",
          "PhoneNumber": "",
          "PhoneAreaCode": "",
          "PhoneCountryCode": ""
        
      ],
      "UpdatedDateUTC": "/Date(1618586879300+0000)/",
      "ContactGroups": [],
      "IsSupplier": false,
      "IsCustomer": true,
      "ContactPersons": [],
      "HasAttachments": false,
      "Attachments": [],
      "HasValidationErrors": false
    
  ]

仅当 PhoneType 为 FAX 时,我才需要在 Phones 中返回“PhoneNumber”的值。所以在这种情况下,我需要返回 0014I000023R123。我真的在努力解决如何实现这一点的语法(我首先是营销人员,而不是开发人员!)。非常感谢您提供任何帮助,谢谢。

【问题讨论】:

【参考方案1】:

我不太擅长 javascript,但以下应该可以工作:

var phoneList = results.Contacts[0].Phones;

将为您提供来自第一个(并且只有一个,假设只有一个)联系人的电话列表。

var fax = phoneList.filter(function (phone) 
    return phone.PhoneType == "FAX";
)[0].PhoneNumber;

将过滤电话列表并返回第一个具有 PhoneType == FAX 的电话,然后获取该电话的电话号码。

因此,在这种情况下,传真将等于 0014I000023R123,您可以将其返回。

希望这个答案会有所帮助,可能有更漂亮的方法可以做到这一点,但我已经对其进行了测试并且它正在工作。

【讨论】:

非常感谢 Albert - 这对我帮助非常大,非常感谢!

以上是关于如何在自定义 Zapier 应用程序中从 Xero 访问特定订单项值?的主要内容,如果未能解决你的问题,请参考以下文章

如何在自定义混合任务中从 Ecto 获取数据

在自定义中从 TextField 中关闭键盘

在自定义 UIView 类中从 UIView 快速创建 IBoutlet [重复]

在自定义 UITableCell 中从 UITextField 调用 textFieldShouldReturn 时遇到问题

Zapier 从 Tsheets 数据在 Google 表格中创建多行

WordPress 中的 Xero 身份验证