Views: 3246
Last Modified: 28.04.2022

  Class $Bitrix.RestClient

Class allows to organize the handling of REST client from Bitrix Framework. If your component operates not only inside Bitrix24 but also as an external widget (online forms, online chat widget), you need to use this class. In the rest of cases, use the import of import {rest as Rest} from 'rest.client'.

Методы $Bitrix.RestClient
$Bitrix.RestClient.get Method for getting current configured REST client for current application (for external third-party applications).
$Bitrix.RestClient.set Method for installing a new REST client in the current Vue application.
$Bitrix.RestClient.isCustom This method can be used to find out, if standard REST client was edited.

$Bitrix.RestClient.get

Method for getting current configured REST client for current application (for external third-party applications).

this.$Bitrix.RestClient.get(): RestClient

Result:

RestClient – configured REST client.

$Bitrix.RestClient.set

Method for setting new REST client in the current Vue application.

this.$Bitrix.RestClient.set(instance: RestClient): void

Parameters:

Parameter Description
instance RestClient - configured REST client.

Additionally:

When the method this.$Bitrix.RestClient.set was not called, uses the REST client by default: BX.rest. It won't be suitable resources and you need to initialize your own client when initializing Vue application. Example can be the function initRestClient, described in the file /bitrix/modules/imopenlines/install/js/imopenlines/component/widget/src/widget.js.

$Bitrix.RestClient.isCustom

Using this method can inform you if the standard REST client was edited.

this.$Bitrix.RestClient.isCustom(): boolean

Event BitrixVue.events.restClientChange

In case, you need to react to a REST client change, you can subscribe to an edit event:

import {BitrixVue} from 'ui.vue3';
this.$Bitrix.eventEmitter.subscribe(BitrixVue.events.restClientChange);

  Examples

Access to functions inside the component is performed in the same manner as to any other variable – via this.. There are, however, nuances of use in the hook beforeCreate. You can find more details in the chapter description.

Setting a specialized REST client

import {BitrixVue} from 'ui.vue3';

class Widget
{
	...
	attachTemplate()
	{
		const restClient = this.restClient;
		        
		this.#application = BitrixVue.createApp({
			components: {
				Component	
			},
			beforeCreate() 
			{
				...
				this.$bitrix.RestClient.set(restClient);
			},
			template: '<Component/>'
		}).mount(this.rootNode);
	}
	...
}

Handling REST client

const Component = {
	...
	created(): void
	{
		this.#rest = this.$Bitrix.RestClient.get();
	},
    methods:
	{
		getProfile(): void
		{
		    this.#rest.callMethod('profile').then(result => {
                console.log(result.data());
            });
        }
    },
	...
});





Courses developed by Bitrix24