mirror of
https://github.com/gosticks/DefinitelyTyped.git
synced 2025-10-16 12:05:41 +00:00
# Conflicts: # amcharts/AmCharts.d.ts # angular-gettext/angular-gettext.d.ts # angular-jwt/angular-jwt.d.ts # angular-material/angular-material.d.ts # angularjs/angular.d.ts # auth0-js/auth0-js.d.ts # aws-lambda/aws-lambda.d.ts # aws-sdk/aws-sdk.d.ts # azure-mobile-apps/azure-mobile-apps.d.ts # azure-mobile-services-client/AzureMobileServicesClient.d.ts # blessed/blessed-tests.ts # blessed/blessed.d.ts # bootbox/bootbox.d.ts # bowser/bowser.d.ts # cache-manager/cache-manager.d.ts # chai-things/chai-things.d.ts # colors/colors.d.ts # cordova/cordova-tests.ts # cordova/plugins/Contacts.d.ts # cordova/plugins/FileSystem.d.ts # couchbase/couchbase.d.ts # cucumber/cucumber-tests.ts # cucumber/cucumber.d.ts # d3/d3.d.ts # dojo/dojo.d.ts # dustjs-linkedin/dustjs-linkedin.d.ts # esprima/esprima.d.ts # express-serve-static-core/express-serve-static-core.d.ts # express-session/express-session.d.ts # fetch-mock/fetch-mock.d.ts # fs-extra/fs-extra.d.ts # fullCalendar/fullCalendar.d.ts # github-electron/github-electron.d.ts # gulp-uglify/gulp-uglify.d.ts # gulp/gulp.d.ts # highcharts/highcharts.d.ts # imap/imap.d.ts # incremental-dom/incremental-dom.d.ts # inversify/inversify.d.ts # ionic/ionic.d.ts # ioredis/ioredis.d.ts # isomorphic-fetch/isomorphic-fetch-tests.ts # jake/jake.d.ts # joi/joi.d.ts # jquery-mockjax/jquery-mockjax.d.ts # jquery/jquery.d.ts # js-data-http/js-data-http-tests.ts # js-data-http/js-data-http.d.ts # js-data/js-data.d.ts # jsdom/jsdom.d.ts # jsts/jsts-tests.ts # knex/knex.d.ts # koa-favicon/koa-favicon.d.ts # koa-router/koa-router-tests.ts # koa-router/koa-router.d.ts # lodash/lodash.d.ts # mailparser/mailparser.d.ts # maquette/maquette.d.ts # material-ui/material-ui.d.ts # matter-js/matter-js.d.ts # moment/moment.d.ts # mongoose-promise/mongoose-promise-tests.ts # mongoose/mongoose-tests.ts # mongoose/mongoose.d.ts # multer/multer.d.ts # ncp/ncp.d.ts # nock/nock.d.ts # node/node-tests.ts # node/node.d.ts # nvd3/nvd3.d.ts # object-assign/object-assign.d.ts # openlayers/openlayers.d.ts # parse/parse.d.ts # pdf/pdf.d.ts # pdfkit/pdfkit.d.ts # pg/pg.d.ts # pixi.js/pixi.js.d.ts # progress/progress.d.ts # pusher-js/pusher-js.d.ts # quill/quill-tests.ts # quill/quill.d.ts # radium/radium.d.ts # ravenjs/ravenjs-tests.ts # react-dropzone/react-dropzone.d.ts # react-mdl/react-mdl.d.ts # react-native/react-native.d.ts # react-notification-system/react-notification-system.d.ts # react-router/history-tests.ts # react-router/react-router-tests.tsx # react-router/react-router.d.ts # react-select/react-select-tests.tsx # react-select/react-select.d.ts # react/react.d.ts # redux-form/redux-form.d.ts # request-promise/request-promise.d.ts # resolve-from/resolve-from.d.ts # riot-api-nodejs/riot-api-nodejs.d.ts # sanitize-html/sanitize-html.d.ts # segment-analytics/segment-analytics.d.ts # simple-assign/simple-assign-tests.ts # simple-assign/simple-assign.d.ts # slate-irc/slate-irc.d.ts # soap/soap.d.ts # socket.io/socket.io.d.ts # sql.js/sql.js-tests.ts # sql.js/sql.js.d.ts # steam/steam.d.ts # stylus/stylus.d.ts # swiper/swiper.d.ts # tedious/tedious.d.ts # threejs/three.d.ts # twilio/twilio.d.ts # underscore/underscore.d.ts # ws/ws.d.ts # yeoman-generator/yeoman-generator.d.ts
133 lines
5.5 KiB
TypeScript
133 lines
5.5 KiB
TypeScript
// Type definitions for Segment's analytics.js
|
||
// Project: https://segment.com/docs/libraries/analytics.js/
|
||
// Definitions by: Andrew Fong <https://github.com/fongandrew>
|
||
// Definitions: https://github.com/DefinitelyTyped/DefinitelyTyped
|
||
|
||
declare interface JQuery {}
|
||
|
||
declare namespace SegmentAnalytics {
|
||
|
||
// Generic options object with integrations
|
||
interface SegmentOpts {
|
||
integrations?: any;
|
||
anonymousId?: string;
|
||
}
|
||
|
||
// The actual analytics.js object
|
||
interface AnalyticsJS {
|
||
|
||
/* Configure Segment with write key */
|
||
load(writeKey: string): void;
|
||
|
||
/* The identify method is how you tie one of your users and their actions
|
||
to a recognizable userId and traits. */
|
||
identify(userId: string, traits?: Object, options?: SegmentOpts,
|
||
callback?: () => void): void;
|
||
identify(userId: string, traits: Object, callback?: () => void): void;
|
||
identify(userId: string, callback?: () => void): void;
|
||
identify(traits?: Object, options?: SegmentOpts,
|
||
callback?: () => void): void;
|
||
identify(traits?: Object, callback?: () => void): void;
|
||
identify(callback: () => void): void;
|
||
|
||
/* The track method lets you record any actions your users perform. */
|
||
track(event: string, properties?: Object, options?: SegmentOpts,
|
||
callback?: () => void): void;
|
||
track(event: string, properties?: Object,
|
||
callback?: () => void): void;
|
||
track(event: string, callback?: () => void): void;
|
||
|
||
/* The page method lets you record page views on your website, along with
|
||
optional extra information about the page being viewed. */
|
||
page(category: string, name: string, properties?: Object,
|
||
options?: SegmentOpts, callback?: () => void): void;
|
||
page(name?: string, properties?: Object,
|
||
options?: SegmentOpts, callback?: () => void): void;
|
||
page(name?: string, properties?: Object, callback?: () => void): void;
|
||
page(name?: string, callback?: () => void): void;
|
||
page(properties?: Object, options?: SegmentOpts,
|
||
callback?: () => void): void;
|
||
page(callback?: () => void): void;
|
||
|
||
/* The group method associates an individual user with a group. The group
|
||
can a company, organization, account, project, team or any other name
|
||
you came up with for the same concept. */
|
||
group(groupId: string, traits?: Object, options?: SegmentOpts,
|
||
callback?: () => void): void;
|
||
group(groupId: string, traits?: Object, callback?: () => void): void;
|
||
group(groupId: string, callback?: () => void): void;
|
||
|
||
/* The alias method combines two previously unassociated user identities.
|
||
This comes in handy if the same user visits from two different devices
|
||
and you want to combine their history.
|
||
|
||
Some providers also don’t alias automatically for you when an anonymous
|
||
user signs up (like Mixpanel), so you need to call alias manually right
|
||
after sign up with their brand new userId. */
|
||
alias(userId: string, previousId?: string, options?: SegmentOpts,
|
||
callback?: () => void): void;
|
||
alias(userId: string, previousId?: string, callback?: () => void): void;
|
||
alias(userId: string, callback?: () => void): void;
|
||
alias(userId: string, options?: SegmentOpts, callback?: () => void): void;
|
||
|
||
/* trackLink is a helper that binds a track call to whenever a link is
|
||
clicked. Usually the page would change before you could call track, but
|
||
with trackLink a small timeout is inserted to give the track call enough
|
||
time to fire. */
|
||
trackLink(elements: JQuery|Element[]|Element,
|
||
event: string|{ (elm: Element): string },
|
||
properties?: Object|{ (elm: Element): Object }): void;
|
||
|
||
/* trackForm is a helper that binds a track call to a form submission.
|
||
Usually the page would change before you could call track, but with
|
||
trackForm a small timeout is inserted to give the track call enough
|
||
time to fire. */
|
||
trackForm(elements: JQuery|Element[]|Element,
|
||
event: string|{ (elm: Element): string },
|
||
properties?: Object|{ (elm: Element): Object }): void;
|
||
|
||
/* The ready method allows you to pass in a callback that will be called as
|
||
soon as all of your enabled integrations have loaded. It’s like jQuery’s
|
||
ready method, except for integrations. */
|
||
ready(callback: () => void): void;
|
||
|
||
/* If you need to clear the user and group id and traits we’ve added a
|
||
reset function that is most commonly used when your identified users
|
||
logout of your application. */
|
||
reset(): void;
|
||
|
||
/* Once Analytics.js loaded, you can retrieve information about the
|
||
currently identified user or group like their id and traits. */
|
||
user(): {
|
||
id(): string;
|
||
logout(): void;
|
||
reset(): void;
|
||
anonymousId(newId?: string): string;
|
||
traits(newTraits?: Object): void;
|
||
}
|
||
|
||
group(): {
|
||
id(): string;
|
||
traits(newTraits?: Object): void;
|
||
}
|
||
|
||
/* Analytics.js has a debug mode that logs helpful messages to the
|
||
console. */
|
||
debug(state?: boolean): void;
|
||
|
||
/* The global analytics object emits events whenever you call alias, group,
|
||
identify, track or page. That way you can listen to those events and run
|
||
your own custom code. */
|
||
on(event: string,
|
||
callback: {
|
||
(event: string, properties: Object, options: SegmentOpts): void
|
||
}): void;
|
||
|
||
/* You can extend the length (in milliseconds) of the method callbacks and
|
||
helpers */
|
||
timeout(milliseconds: number): void;
|
||
}
|
||
}
|
||
|
||
declare var analytics: SegmentAnalytics.AnalyticsJS;
|