mirror of
https://github.com/gosticks/DefinitelyTyped.git
synced 2025-10-16 12:05:41 +00:00
314 lines
8.2 KiB
TypeScript
314 lines
8.2 KiB
TypeScript
/// <reference path="backbone.d.ts" />
|
|
/// <reference path="../jquery/jquery.d.ts" />
|
|
|
|
function test_events() {
|
|
|
|
var object = new Backbone.Events();
|
|
object.on("alert", (eventName: string) => alert("Triggered " + eventName));
|
|
|
|
object.trigger("alert", "an event");
|
|
|
|
var onChange = () => alert('whatever');
|
|
var context: any;
|
|
|
|
object.off("change", onChange);
|
|
object.off("change");
|
|
object.off(null, onChange);
|
|
object.off(null, null, context);
|
|
object.off();
|
|
}
|
|
|
|
class SettingDefaults extends Backbone.Model {
|
|
|
|
// 'defaults' could be set in one of the following ways:
|
|
|
|
defaults() {
|
|
return {
|
|
name: "Joe"
|
|
}
|
|
}
|
|
|
|
constructor(attributes?: any, options?: any) {
|
|
this.defaults = <any>{
|
|
name: "Joe"
|
|
}
|
|
// super has to come last
|
|
super(attributes, options);
|
|
}
|
|
|
|
// or set it like this
|
|
initialize() {
|
|
this.defaults = <any>{
|
|
name: "Joe"
|
|
}
|
|
|
|
}
|
|
|
|
// same patterns could be used for setting 'Router.routes' and 'View.events'
|
|
}
|
|
|
|
class Sidebar extends Backbone.Model {
|
|
|
|
promptColor() {
|
|
var cssColor = prompt("Please enter a CSS color:");
|
|
this.set({ color: cssColor });
|
|
}
|
|
}
|
|
|
|
class Note extends Backbone.Model {
|
|
initialize() { }
|
|
author() { }
|
|
coordinates() { }
|
|
allowedToEdit(account: any) {
|
|
return true;
|
|
}
|
|
}
|
|
|
|
class PrivateNote extends Note {
|
|
allowedToEdit(account: any) {
|
|
return account.owns(this);
|
|
}
|
|
|
|
set(attributes: any, options?: any): Backbone.Model {
|
|
return Backbone.Model.prototype.set.call(this, attributes, options);
|
|
}
|
|
}
|
|
|
|
function test_models() {
|
|
|
|
var sidebar = new Sidebar();
|
|
sidebar.on('change:color', (model: {}, color: string) => $('#sidebar').css({ background: color }));
|
|
sidebar.set({ color: 'white' });
|
|
sidebar.promptColor();
|
|
|
|
//////////
|
|
|
|
var note = new PrivateNote();
|
|
|
|
note.get("title");
|
|
|
|
note.set({ title: "March 20", content: "In his eyes she eclipses..." });
|
|
|
|
note.set("title", "A Scandal in Bohemia");
|
|
}
|
|
|
|
class Employee extends Backbone.Model {
|
|
reports: EmployeeCollection;
|
|
|
|
constructor(attributes?: any, options?: any) {
|
|
super(options);
|
|
this.reports = new EmployeeCollection();
|
|
this.reports.url = '../api/employees/' + this.id + '/reports';
|
|
}
|
|
|
|
more() {
|
|
this.reports.reset();
|
|
}
|
|
}
|
|
|
|
class EmployeeCollection extends Backbone.Collection<Employee> {
|
|
findByName(key: any) { }
|
|
}
|
|
|
|
class Book extends Backbone.Model {
|
|
title: string;
|
|
author: string;
|
|
published: boolean;
|
|
}
|
|
|
|
class Library extends Backbone.Collection<Book> {
|
|
// This model definition is here only to test type compatibility of the model, but it
|
|
// is not necessary in working code as it is automatically inferred through generics.
|
|
model: typeof Book;
|
|
}
|
|
|
|
class Books extends Backbone.Collection<Book> { }
|
|
|
|
function test_collection() {
|
|
|
|
var books = new Books();
|
|
|
|
var book1: Book = new Book({ title: "Title 1", author: "Mike" });
|
|
books.add(book1);
|
|
|
|
// Objects can be added to collection by casting to model type.
|
|
// Compiler will check if object properties are valid for the cast.
|
|
// This gives better type checking than declaring an `any` overload.
|
|
books.add(<Book>{ title: "Title 2", author: "Mikey" });
|
|
|
|
var model: Book = book1.collection.first();
|
|
if (model !== book1) {
|
|
throw new Error("Error");
|
|
}
|
|
|
|
books.each(book =>
|
|
book.get("title"));
|
|
|
|
var titles = books.map(book =>
|
|
book.get("title"));
|
|
|
|
var publishedBooks = books.filter(book =>
|
|
book.get("published") === true);
|
|
|
|
var alphabetical = books.sortBy((book: Book): number => null);
|
|
}
|
|
|
|
//////////
|
|
|
|
Backbone.history.start();
|
|
|
|
module v1Changes {
|
|
module events {
|
|
function test_once() {
|
|
var model = new Employee;
|
|
model.once('invalid', () => { }, this);
|
|
model.once('invalid', () => { });
|
|
}
|
|
|
|
function test_listenTo() {
|
|
var model = new Employee;
|
|
var view = new Backbone.View<Employee>();
|
|
view.listenTo(model, 'invalid', () => { });
|
|
}
|
|
|
|
function test_listenToOnce() {
|
|
var model = new Employee;
|
|
var view = new Backbone.View<Employee>();
|
|
view.listenToOnce(model, 'invalid', () => { });
|
|
}
|
|
|
|
function test_stopListening() {
|
|
var model = new Employee;
|
|
var view = new Backbone.View<Employee>();
|
|
view.stopListening(model, 'invalid', () => { });
|
|
view.stopListening(model, 'invalid');
|
|
view.stopListening(model);
|
|
}
|
|
}
|
|
|
|
module ModelAndCollection {
|
|
function test_url() {
|
|
Employee.prototype.url = () => '/employees';
|
|
EmployeeCollection.prototype.url = () => '/employees';
|
|
}
|
|
|
|
function test_parse() {
|
|
var model = new Employee();
|
|
model.parse('{}', {});
|
|
var collection = new EmployeeCollection;
|
|
collection.parse('{}', {});
|
|
}
|
|
|
|
function test_toJSON() {
|
|
var model = new Employee();
|
|
model.toJSON({});
|
|
var collection = new EmployeeCollection;
|
|
collection.toJSON({});
|
|
}
|
|
|
|
function test_sync() {
|
|
var model = new Employee();
|
|
model.sync();
|
|
var collection = new EmployeeCollection;
|
|
collection.sync();
|
|
}
|
|
}
|
|
|
|
module Model {
|
|
function test_validationError() {
|
|
var model = new Employee;
|
|
if (model.validationError) {
|
|
console.log('has validation errors');
|
|
}
|
|
}
|
|
|
|
function test_fetch() {
|
|
var model = new Employee({ id: 1 });
|
|
model.fetch({
|
|
success: () => { },
|
|
error: () => { }
|
|
});
|
|
}
|
|
|
|
function test_set() {
|
|
var model = new Employee;
|
|
model.set({ name: 'JoeDoe', age: 21 }, { validate: false });
|
|
model.set('name', 'JoeDoes', { validate: false });
|
|
}
|
|
|
|
function test_destroy() {
|
|
var model = new Employee;
|
|
model.destroy({
|
|
wait: true,
|
|
success: (m?, response?, options?) => { },
|
|
error: (m?, jqxhr?, options?) => { }
|
|
});
|
|
|
|
model.destroy({
|
|
success: (m?, response?, options?) => { },
|
|
error: (m?, jqxhr?) => { }
|
|
});
|
|
|
|
model.destroy({
|
|
success: () => { },
|
|
error: (m?, jqxhr?) => { }
|
|
});
|
|
}
|
|
|
|
function test_save() {
|
|
var model = new Employee;
|
|
|
|
model.save({
|
|
name: 'Joe Doe',
|
|
age: 21
|
|
},
|
|
{
|
|
wait: true,
|
|
validate: false,
|
|
success: (m?, response?, options?) => { },
|
|
error: (m?, jqxhr?, options?) => { }
|
|
});
|
|
|
|
model.save({
|
|
name: 'Joe Doe',
|
|
age: 21
|
|
},
|
|
{
|
|
success: () => { },
|
|
error: (m?, jqxhr?) => { }
|
|
});
|
|
}
|
|
|
|
function test_validate() {
|
|
var model = new Employee;
|
|
|
|
model.validate({ name: 'JoeDoe', age: 21 }, { validateAge: false })
|
|
}
|
|
}
|
|
|
|
module Collection {
|
|
function test_fetch() {
|
|
var collection = new EmployeeCollection;
|
|
collection.fetch({ reset: true });
|
|
}
|
|
|
|
function test_create() {
|
|
var collection = new EmployeeCollection;
|
|
var model = new Employee;
|
|
|
|
collection.create(model, {
|
|
validate: false
|
|
});
|
|
}
|
|
}
|
|
|
|
module Router {
|
|
function test_navigate() {
|
|
var router = new Backbone.Router;
|
|
|
|
router.navigate('/employees', { trigger: true });
|
|
router.navigate('/employees', true);
|
|
}
|
|
}
|
|
}
|