Skip to content

make-software/make-traffic-integration-lib

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

13 Commits
 
 
 
 
 
 
 
 

Repository files navigation

Make Traffic Integration JS Library

The project contains modular JavaScript libraries designed for managing tasks in a traffic exchange system. It consists of a core npm package and framework-specific wrappers for popular frameworks. The core library is framework-agnostic, written in TypeScript, and compiled to JavaScript.


Installation

npm install make-traffic-integration-core

Initialization

To use the library, initialize the TaskManagerApp instance with your app's configuration:

import { TaskManagerApp } from "npm install make-traffic-integration-core";

const appConfig = {
    apiUrl: 'https://make-traffic-integration.dev.make.services',
    appKey: '<!--YourAppKey-->',
};

const taskManager = new TaskManagerApp(appConfig);
taskManager.init(); // Initialize the library

Example

const onCampaignClaimed = (task: Campaign) => {
    console.log('Campaign claimed:', task);
};

taskManager.subscribe(Events.CampaignClaimSucceed, onCampaignClaimed);

taskManager.getCampaigns('user123').then(campaigns => {
    console.log('Campaigns:', campaigns);
});

**React Example with wrapper library **

  npm install make-traffic-integration-react-wrapper

Check React Example

Code Example

import React from "react";
import { TaskManagerProvider } from "make-traffic-integration-react-wrapper";
import {TaskManagerApp} from "make-traffic-integration-core";

const taskManagerApp = TaskManagerApp({
    apiUrl: "https://api.example.com",
    appKey: "your-app-key",
});

const MyCustomTemplate = (campaign, actions) => (
    <div>
        <h3>{campaign.name}</h3>
        <button onClick={actions.go}>Go</button>
        <button onClick={actions.claim}>Claim</button>
    </div>
);

const App = () => (
    <TaskManagerProvider
        taskManagerApp={taskManagerApp}
        userID="user123"
        template={MyCustomTemplate}
    />
);

export default App;

Core Methods

async init(): Promise<void>

Initializes the task manager. Should be run once before using other methods.

async getCampaigns(userID: string): Promise<CampaignList>

Fetches the list of campaigns available for the specified user.

async goProcess(userID: string, task: Campaign): Promise<void>

Processes the specified campaign task.

async claimProcess(userID: string, task: Campaign): Promise<void>

Claims the specified campaign task for the user.

subscribe(event: Events, callback: (task: Campaign) => void): void

Subscribes to a specific event related to campaign tasks.

unsubscribe(event: Events, callback: (task: Campaign) => void): void

Unsubscribes from a previously subscribed event.

Events

Events.CampaignClaimSucceed

Triggered when a campaign is successfully claimed.

Events.CampaignClaimFailed

Triggered when claiming a campaign fails.

Events.CampaignProcessed

Triggered when a campaign has been successfully processed.

License

MIT

About

No description, website, or topics provided.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published