diff options
| author | Eleanor Eng <eleanor_eng@brown.edu> | 2019-05-04 16:44:22 -0400 | 
|---|---|---|
| committer | Eleanor Eng <eleanor_eng@brown.edu> | 2019-05-04 16:44:40 -0400 | 
| commit | cecd09917f23fc83c87cffc4fddf5fe1f8331bac (patch) | |
| tree | ab7144d36046aaada287c2ce14d2fe7722585dce /src/fields | |
| parent | 0bf0b028b1af8b9481e369c754277af5fb8b3fcd (diff) | |
| parent | 1ccabe155cb4f23c0aa7e37f91cd4a303008b8c7 (diff) | |
merge with master
Diffstat (limited to 'src/fields')
| -rw-r--r-- | src/fields/AudioField.ts | 31 | ||||
| -rw-r--r-- | src/fields/BasicField.ts | 59 | ||||
| -rw-r--r-- | src/fields/BooleanField.ts | 25 | ||||
| -rw-r--r-- | src/fields/Document.ts | 430 | ||||
| -rw-r--r-- | src/fields/DocumentReference.ts | 57 | ||||
| -rw-r--r-- | src/fields/Field.ts | 69 | ||||
| -rw-r--r-- | src/fields/FieldUpdatedArgs.ts | 27 | ||||
| -rw-r--r-- | src/fields/HtmlField.ts | 25 | ||||
| -rw-r--r-- | src/fields/IconFIeld.ts | 25 | ||||
| -rw-r--r-- | src/fields/ImageField.ts | 29 | ||||
| -rw-r--r-- | src/fields/InkField.ts | 53 | ||||
| -rw-r--r-- | src/fields/Key.ts | 50 | ||||
| -rw-r--r-- | src/fields/KeyStore.ts | 67 | ||||
| -rw-r--r-- | src/fields/ListField.ts | 196 | ||||
| -rw-r--r-- | src/fields/NumberField.ts | 25 | ||||
| -rw-r--r-- | src/fields/PDFField.ts | 36 | ||||
| -rw-r--r-- | src/fields/RichTextField.ts | 26 | ||||
| -rw-r--r-- | src/fields/ScriptField.ts | 174 | ||||
| -rw-r--r-- | src/fields/TemplateField.ts | 43 | ||||
| -rw-r--r-- | src/fields/TextField.ts | 25 | ||||
| -rw-r--r-- | src/fields/TupleField.ts | 59 | ||||
| -rw-r--r-- | src/fields/VideoField.ts | 30 | ||||
| -rw-r--r-- | src/fields/WebField.ts | 30 | 
23 files changed, 130 insertions, 1461 deletions
| diff --git a/src/fields/AudioField.ts b/src/fields/AudioField.ts deleted file mode 100644 index 87e47a715..000000000 --- a/src/fields/AudioField.ts +++ /dev/null @@ -1,31 +0,0 @@ -import { BasicField } from "./BasicField"; -import { Field, FieldId } from "./Field"; -import { Types } from "../server/Message"; - -export class AudioField extends BasicField<URL> { -    constructor(data: URL | undefined = undefined, id?: FieldId, save: boolean = true) { -        super(data === undefined ? new URL("http://techslides.com/demos/samples/sample.mp3") : data, save, id); -    } - -    toString(): string { -        return this.Data.href; -    } - - -    ToScriptString(): string { -        return `new AudioField("${this.Data}")`; -    } - -    Copy(): Field { -        return new AudioField(this.Data); -    } - -    ToJson() { -        return { -            type: Types.Audio, -            data: this.Data.href, -            id: this.Id -        }; -    } - -}
\ No newline at end of file diff --git a/src/fields/BasicField.ts b/src/fields/BasicField.ts deleted file mode 100644 index 17b1fc4e8..000000000 --- a/src/fields/BasicField.ts +++ /dev/null @@ -1,59 +0,0 @@ -import { Field, FieldId } from "./Field"; -import { observable, computed, action } from "mobx"; -import { Server } from "../client/Server"; -import { UndoManager } from "../client/util/UndoManager"; - -export abstract class BasicField<T> extends Field { -    constructor(data: T, save: boolean, id?: FieldId) { -        super(id); - -        this.data = data; -        if (save) { -            Server.UpdateField(this); -        } -    } - -    UpdateFromServer(data: any) { -        if (this.data !== data) { -            this.data = data; -        } -    } - -    @observable -    protected data: T; - -    @computed -    get Data(): T { -        return this.data; -    } - -    set Data(value: T) { -        if (this.data === value) { -            return; -        } -        let oldValue = this.data; -        this.setData(value); -        UndoManager.AddEvent({ -            undo: () => this.Data = oldValue, -            redo: () => this.Data = value -        }); -        Server.UpdateField(this); -    } - -    protected setData(value: T) { -        this.data = value; -    } - -    @action -    TrySetValue(value: any): boolean { -        if (typeof value === typeof this.data) { -            this.Data = value; -            return true; -        } -        return false; -    } - -    GetValue(): any { -        return this.Data; -    } -} diff --git a/src/fields/BooleanField.ts b/src/fields/BooleanField.ts deleted file mode 100644 index d49bfe82b..000000000 --- a/src/fields/BooleanField.ts +++ /dev/null @@ -1,25 +0,0 @@ -import { BasicField } from "./BasicField"; -import { FieldId } from "./Field"; -import { Types } from "../server/Message"; - -export class BooleanField extends BasicField<boolean> { -    constructor(data: boolean = false as boolean, id?: FieldId, save: boolean = true as boolean) { -        super(data, save, id); -    } - -    ToScriptString(): string { -        return `new BooleanField("${this.Data}")`; -    } - -    Copy() { -        return new BooleanField(this.Data); -    } - -    ToJson() { -        return { -            type: Types.Boolean, -            data: this.Data, -            id: this.Id -        }; -    } -} diff --git a/src/fields/Document.ts b/src/fields/Document.ts deleted file mode 100644 index 7cf784f0e..000000000 --- a/src/fields/Document.ts +++ /dev/null @@ -1,430 +0,0 @@ -import { Key } from "./Key"; -import { KeyStore } from "./KeyStore"; -import { Field, Cast, FieldWaiting, FieldValue, FieldId, Opt } from "./Field"; -import { NumberField } from "./NumberField"; -import { ObservableMap, computed, action, runInAction } from "mobx"; -import { TextField } from "./TextField"; -import { ListField } from "./ListField"; -import { Server } from "../client/Server"; -import { Types } from "../server/Message"; -import { UndoManager } from "../client/util/UndoManager"; -import { HtmlField } from "./HtmlField"; -import { BooleanField } from "./BooleanField"; -import { allLimit } from "async"; -import { prototype } from "nodemailer/lib/smtp-pool"; -import { HistogramField } from "../client/northstar/dash-fields/HistogramField"; - -export class Document extends Field { -    //TODO tfs: We should probably store FieldWaiting in fields when we request it from the server so that we don't set up multiple server gets for the same document and field -    public fields: ObservableMap<string, { key: Key; field: Field }> = new ObservableMap(); -    public _proxies: ObservableMap<string, FieldId> = new ObservableMap(); - -    constructor(id?: string, save: boolean = true) { -        super(id); - -        if (save) { -            Server.UpdateField(this); -        } -    } -    static FromJson(data: any, id: string, save: boolean): Document { -        let doc = new Document(id, save); -        let fields = data as [string, string][]; -        fields.forEach(pair => doc._proxies.set(pair[0], pair[1])); -        return doc; -    } - -    UpdateFromServer(data: [string, string][]) { -        for (const key in data) { -            const element = data[key]; -            this._proxies.set(element[0], element[1]); -        } -    } - -    public Width = () => this.GetNumber(KeyStore.Width, 0); -    public Height = () => this.GetNumber(KeyStore.Height, this.GetNumber(KeyStore.NativeWidth, 0) ? (this.GetNumber(KeyStore.NativeHeight, 0) / this.GetNumber(KeyStore.NativeWidth, 0)) * this.GetNumber(KeyStore.Width, 0) : 0); -    public Scale = () => this.GetNumber(KeyStore.Scale, 1); - -    @computed -    public get Title(): string { -        let title = this.Get(KeyStore.Title, true); -        if (title || title === FieldWaiting) { -            if (title !== FieldWaiting && title instanceof TextField) { -                return title.Data; -            } -            else return "-waiting-"; -        } -        let parTitle = this.GetT(KeyStore.Title, TextField); -        if (parTitle || parTitle === FieldWaiting) { -            if (parTitle !== FieldWaiting) return parTitle.Data + ".alias"; -            else return "-waiting-.alias"; -        } -        return "-untitled-"; -    } - -    @computed -    public get Fields() { -        return this.fields; -    } - -    /** -     * Get the field in the document associated with the given key. If the -     * associated field has not yet been filled in from the server, a request -     * to the server will automatically be sent, the value will be filled in -     * when the request is completed, and {@link Field.ts#FieldWaiting} will be returned. -     * @param key - The key of the value to get -     * @param ignoreProto - If true, ignore any prototype this document -     * might have and only search for the value on this immediate document. -     * If false (default), search up the prototype chain, starting at this document, -     * for a document that has a field associated with the given key, and return the first -     * one found. -     * -     * @returns If the document does not have a field associated with the given key, returns `undefined`. -     * If the document does have an associated field, but the field has not been fetched from the server, returns {@link Field.ts#FieldWaiting}. -     * If the document does have an associated field, and the field has not been fetched from the server, returns the associated field. -     */ -    Get(key: Key, ignoreProto: boolean = false): FieldValue<Field> { -        let field: FieldValue<Field>; -        if (ignoreProto) { -            if (this.fields.has(key.Id)) { -                field = this.fields.get(key.Id)!.field; -            } else if (this._proxies.has(key.Id)) { -                Server.GetDocumentField(this, key); -                /* -                        The field might have been instantly filled from the cache -                        Maybe we want to just switch back to returning the value -                        from Server.GetDocumentField if it's in the cache -                        */ -                if (this.fields.has(key.Id)) { -                    field = this.fields.get(key.Id)!.field; -                } else { -                    field = FieldWaiting; -                } -            } -        } else { -            let doc: FieldValue<Document> = this; -            while (doc && field !== FieldWaiting) { -                let curField = doc.fields.get(key.Id); -                let curProxy = doc._proxies.get(key.Id); -                if (!curField || (curProxy && curField.field.Id !== curProxy)) { -                    if (curProxy) { -                        Server.GetDocumentField(doc, key); -                        /* -                                    The field might have been instantly filled from the cache -                                    Maybe we want to just switch back to returning the value -                                    from Server.GetDocumentField if it's in the cache -                                    */ -                        if (this.fields.has(key.Id)) { -                            field = this.fields.get(key.Id)!.field; -                        } else { -                            field = FieldWaiting; -                        } -                        break; -                    } -                    if ( -                        doc.fields.has(KeyStore.Prototype.Id) || -                        doc._proxies.has(KeyStore.Prototype.Id) -                    ) { -                        doc = doc.GetPrototype(); -                    } else { -                        break; -                    } -                } else { -                    field = curField.field; -                    break; -                } -            } -            if (doc === FieldWaiting) field = FieldWaiting; -        } - -        return field; -    } - -    /** -     * Tries to get the field associated with the given key, and if there is an -     * associated field, calls the given callback with that field. -     * @param key - The key of the value to get -     * @param callback - A function that will be called with the associated field, if it exists, -     * once it is fetched from the server (this may be immediately if the field has already been fetched). -     * Note: The callback will not be called if there is no associated field. -     * @returns `true` if the field exists on the document and `callback` will be called, and `false` otherwise -     */ -    GetAsync(key: Key, callback: (field: Opt<Field>) => void): void { -        //TODO: This currently doesn't deal with prototypes -        let field = this.fields.get(key.Id); -        if (field && field.field) { -            callback(field.field); -        } else if (this._proxies.has(key.Id)) { -            Server.GetDocumentField(this, key, callback); -        } else if (this._proxies.has(KeyStore.Prototype.Id)) { -            this.GetTAsync(KeyStore.Prototype, Document, proto => { -                if (proto) { -                    proto.GetAsync(key, callback); -                } else { -                    callback(undefined); -                } -            }); -        } else { -            callback(undefined); -        } -    } - -    GetTAsync<T extends Field>(key: Key, ctor: { new(): T }): Promise<Opt<T>>; -    GetTAsync<T extends Field>( -        key: Key, -        ctor: { new(): T }, -        callback: (field: Opt<T>) => void -    ): void; -    GetTAsync<T extends Field>( -        key: Key, -        ctor: { new(): T }, -        callback?: (field: Opt<T>) => void -    ): Promise<Opt<T>> | void { -        let fn = (cb: (field: Opt<T>) => void) => { -            return this.GetAsync(key, field => { -                cb(Cast(field, ctor)); -            }); -        }; -        if (callback) { -            fn(callback); -        } else { -            return new Promise(fn); -        } -    } - -    /** -     * Same as {@link Document#GetAsync}, except a field of the given type -     * will be created if there is no field associated with the given key, -     * or the field associated with the given key is not of the given type. -     * @param ctor - Constructor of the field type to get. E.g., TextField, ImageField, etc. -     */ -    GetOrCreateAsync<T extends Field>( -        key: Key, -        ctor: { new(): T }, -        callback: (field: T) => void -    ): void { -        //This currently doesn't deal with prototypes -        if (this._proxies.has(key.Id)) { -            Server.GetDocumentField(this, key, field => { -                if (field && field instanceof ctor) { -                    callback(field); -                } else { -                    let newField = new ctor(); -                    this.Set(key, newField); -                    callback(newField); -                } -            }); -        } else { -            let newField = new ctor(); -            this.Set(key, newField); -            callback(newField); -        } -    } - -    /** -     * Same as {@link Document#Get}, except that it will additionally -     * check if the field is of the given type. -     * @param ctor - Constructor of the field type to get. E.g., `TextField`, `ImageField`, etc. -     * @returns Same as {@link Document#Get}, except will return `undefined` -     * if there is an associated field but it is of the wrong type. -     */ -    GetT<T extends Field = Field>( -        key: Key, -        ctor: { new(...args: any[]): T }, -        ignoreProto: boolean = false -    ): FieldValue<T> { -        var getfield = this.Get(key, ignoreProto); -        if (getfield !== FieldWaiting) { -            return Cast(getfield, ctor); -        } -        return FieldWaiting; -    } - -    GetOrCreate<T extends Field>( -        key: Key, -        ctor: { new(): T }, -        ignoreProto: boolean = false -    ): T { -        const field = this.GetT(key, ctor, ignoreProto); -        if (field && field !== FieldWaiting) { -            return field; -        } -        const newField = new ctor(); -        this.Set(key, newField); -        return newField; -    } - -    GetData<T, U extends Field & { Data: T }>( -        key: Key, -        ctor: { new(): U }, -        defaultVal: T -    ): T { -        let val = this.Get(key); -        let vval = val && val instanceof ctor ? val.Data : defaultVal; -        return vval; -    } - -    GetHtml(key: Key, defaultVal: string): string { -        return this.GetData(key, HtmlField, defaultVal); -    } - -    GetBoolean(key: Key, defaultVal: boolean): boolean { -        return this.GetData(key, BooleanField, defaultVal); -    } - -    GetNumber(key: Key, defaultVal: number): number { -        return this.GetData(key, NumberField, defaultVal); -    } - -    GetText(key: Key, defaultVal: string): string { -        return this.GetData(key, TextField, defaultVal); -    } - -    GetList<T extends Field>(key: Key, defaultVal: T[]): T[] { -        return this.GetData<T[], ListField<T>>(key, ListField, defaultVal); -    } - -    @action -    Set(key: Key, field: Field | undefined, setOnPrototype = false): void { -        let old = this.fields.get(key.Id); -        let oldField = old ? old.field : undefined; -        if (setOnPrototype) { -            this.SetOnPrototype(key, field); -        } else { -            if (field) { -                this.fields.set(key.Id, { key, field }); -                this._proxies.set(key.Id, field.Id); -                // Server.AddDocumentField(this, key, field); -            } else { -                this.fields.delete(key.Id); -                this._proxies.delete(key.Id); -                // Server.DeleteDocumentField(this, key); -            } -            Server.UpdateField(this); -        } -        if (oldField || field) { -            UndoManager.AddEvent({ -                undo: () => this.Set(key, oldField, setOnPrototype), -                redo: () => this.Set(key, field, setOnPrototype) -            }); -        } -    } - -    @action -    SetOnPrototype(key: Key, field: Field | undefined): void { -        this.GetTAsync(KeyStore.Prototype, Document, (f: Opt<Document>) => { -            f && f.Set(key, field); -        }); -    } - -    @action -    SetDataOnPrototype<T, U extends Field & { Data: T }>(key: Key, value: T, ctor: { new(): U }, replaceWrongType = true) { -        this.GetTAsync(KeyStore.Prototype, Document, (f: Opt<Document>) => { -            f && f.SetData(key, value, ctor, replaceWrongType); -        }); -    } - -    @action -    SetData<T, U extends Field & { Data: T }>(key: Key, value: T, ctor: { new(data: T): U }, replaceWrongType = true) { -        let field = this.Get(key, true); -        if (field instanceof ctor) { -            field.Data = value; -        } else if (!field || replaceWrongType) { -            let newField = new ctor(value); -            // newField.Data = value; -            this.Set(key, newField); -        } -    } - -    @action -    SetText(key: Key, value: string, replaceWrongType = true) { -        this.SetData(key, value, TextField, replaceWrongType); -    } -    @action -    SetBoolean(key: Key, value: boolean, replaceWrongType = true) { -        this.SetData(key, value, BooleanField, replaceWrongType); -    } -    @action -    SetNumber(key: Key, value: number, replaceWrongType = true) { -        this.SetData(key, value, NumberField, replaceWrongType); -    } - -    GetPrototype(): FieldValue<Document> { -        return this.GetT(KeyStore.Prototype, Document, true); -    } - -    GetAllPrototypes(): Document[] { -        let protos: Document[] = []; -        let doc: FieldValue<Document> = this; -        while (doc && doc !== FieldWaiting) { -            protos.push(doc); -            doc = doc.GetPrototype(); -        } -        return protos; -    } - -    CreateAlias(id?: string): Document { -        let alias = new Document(id); -        this.GetTAsync(KeyStore.Prototype, Document, (f: Opt<Document>) => { -            f && alias.Set(KeyStore.Prototype, f); -        }); - -        return alias; -    } - -    MakeDelegate(id?: string): Document { -        let delegate = new Document(id); - -        delegate.Set(KeyStore.Prototype, this); - -        return delegate; -    } - -    ToScriptString(): string { -        return ""; -    } - -    TrySetValue(value: any): boolean { -        throw new Error("Method not implemented."); -    } -    GetValue() { -        return this.Title; -        var title = (this._proxies.has(KeyStore.Title.Id) ? "???" : this.Title) + "(" + this.Id + ")"; -        return title; -        //throw new Error("Method not implemented."); -    } -    Copy(copyProto?: boolean, id?: string): Field { -        let copy = new Document(); -        this._proxies.forEach((fieldid, keyid) => { // copy each prototype field -            let key = KeyStore.KeyLookup(keyid); -            if (key) { -                this.GetAsync(key, (field: Opt<Field>) => { -                    if (key === KeyStore.Prototype && copyProto) { // handle prototype field specially -                        if (field instanceof Document) { -                            copy.Set(key, field.Copy(false)); // only copying one level of prototypes for now... -                        } -                    } -                    else -                        if (field instanceof Document) {  // ... TODO bcz: should we copy documents or reference them -                            copy.Set(key!, field); -                        } -                        else if (field) { -                            copy.Set(key!, field.Copy()); -                        } -                }); -            } -        }); -        return copy; -    } - -    ToJson() { -        let fields: [string, string][] = []; -        this._proxies.forEach((field, key) => -            field && fields.push([key, field])); - -        return { -            type: Types.Document, -            data: fields, -            id: this.Id -        }; -    } -} diff --git a/src/fields/DocumentReference.ts b/src/fields/DocumentReference.ts deleted file mode 100644 index 303754177..000000000 --- a/src/fields/DocumentReference.ts +++ /dev/null @@ -1,57 +0,0 @@ -import { Field, Opt, FieldValue, FieldId } from "./Field"; -import { Document } from "./Document"; -import { Key } from "./Key"; -import { Types } from "../server/Message"; -import { ObjectID } from "bson"; - -export class DocumentReference extends Field { -    get Key(): Key { -        return this.key; -    } - -    get Document(): Document { -        return this.document; -    } - -    constructor(private document: Document, private key: Key) { -        super(); -    } - -    UpdateFromServer() { - -    } - -    Dereference(): FieldValue<Field> { -        return this.document.Get(this.key); -    } - -    DereferenceToRoot(): FieldValue<Field> { -        let field: FieldValue<Field> = this; -        while (field instanceof DocumentReference) { -            field = field.Dereference(); -        } -        return field; -    } - -    TrySetValue(value: any): boolean { -        throw new Error("Method not implemented."); -    } -    GetValue() { -        throw new Error("Method not implemented."); -    } -    Copy(): Field { -        throw new Error("Method not implemented."); -    } - -    ToScriptString(): string { -        return ""; -    } - -    ToJson() { -        return { -            type: Types.DocumentReference, -            data: this.document.Id, -            id: this.Id -        }; -    } -}
\ No newline at end of file diff --git a/src/fields/Field.ts b/src/fields/Field.ts deleted file mode 100644 index 3b3e95c2b..000000000 --- a/src/fields/Field.ts +++ /dev/null @@ -1,69 +0,0 @@ - -import { Utils } from "../Utils"; -import { Types, Transferable } from "../server/Message"; -import { computed } from "mobx"; - -export function Cast<T extends Field>(field: FieldValue<Field>, ctor: { new(): T }): Opt<T> { -    if (field) { -        if (ctor && field instanceof ctor) { -            return field; -        } -    } -    return undefined; -} - -export const FieldWaiting: FIELD_WAITING = null; -export type FIELD_WAITING = null; -export type FieldId = string; -export type Opt<T> = T | undefined; -export type FieldValue<T> = Opt<T> | FIELD_WAITING; - -export abstract class Field { -    //FieldUpdated: TypedEvent<Opt<FieldUpdatedArgs>> = new TypedEvent<Opt<FieldUpdatedArgs>>(); - -    init(callback: (res: Field) => any) { -        callback(this); -    } - -    private id: FieldId; - -    @computed -    get Id(): FieldId { -        return this.id; -    } - -    constructor(id: Opt<FieldId> = undefined) { -        this.id = id || Utils.GenerateGuid(); -    } - -    Dereference(): FieldValue<Field> { -        return this; -    } -    DereferenceToRoot(): FieldValue<Field> { -        return this; -    } - -    DereferenceT<T extends Field = Field>(ctor: { new(): T }): FieldValue<T> { -        return Cast(this.Dereference(), ctor); -    } - -    DereferenceToRootT<T extends Field = Field>(ctor: { new(): T }): FieldValue<T> { -        return Cast(this.DereferenceToRoot(), ctor); -    } - -    Equals(other: Field): boolean { -        return this.id === other.id; -    } - -    abstract UpdateFromServer(serverData: any): void; - -    abstract ToScriptString(): string; - -    abstract TrySetValue(value: any): boolean; - -    abstract GetValue(): any; - -    abstract Copy(): Field; - -    abstract ToJson(): Transferable; -}
\ No newline at end of file diff --git a/src/fields/FieldUpdatedArgs.ts b/src/fields/FieldUpdatedArgs.ts deleted file mode 100644 index 23ccf2a5a..000000000 --- a/src/fields/FieldUpdatedArgs.ts +++ /dev/null @@ -1,27 +0,0 @@ -import { Field, Opt } from "./Field"; -import { Document } from "./Document"; -import { Key } from "./Key"; - -export enum FieldUpdatedAction { -    Add, -    Remove, -    Replace, -    Update -} - -export interface FieldUpdatedArgs { -    field: Field; -    action: FieldUpdatedAction; -} - -export interface DocumentUpdatedArgs { -    field: Document; -    key: Key; - -    oldValue: Opt<Field>; -    newValue: Opt<Field>; - -    fieldArgs?: FieldUpdatedArgs; - -    action: FieldUpdatedAction; -} diff --git a/src/fields/HtmlField.ts b/src/fields/HtmlField.ts deleted file mode 100644 index a1d880070..000000000 --- a/src/fields/HtmlField.ts +++ /dev/null @@ -1,25 +0,0 @@ -import { BasicField } from "./BasicField"; -import { Types } from "../server/Message"; -import { FieldId } from "./Field"; - -export class HtmlField extends BasicField<string> { -    constructor(data: string = "<html></html>", id?: FieldId, save: boolean = true) { -        super(data, save, id); -    } - -    ToScriptString(): string { -        return `new HtmlField("${this.Data}")`; -    } - -    Copy() { -        return new HtmlField(this.Data); -    } - -    ToJson() { -        return { -            type: Types.Html, -            data: this.Data, -            id: this.Id, -        }; -    } -}
\ No newline at end of file diff --git a/src/fields/IconFIeld.ts b/src/fields/IconFIeld.ts deleted file mode 100644 index a6694cc49..000000000 --- a/src/fields/IconFIeld.ts +++ /dev/null @@ -1,25 +0,0 @@ -import { BasicField } from "./BasicField"; -import { FieldId } from "./Field"; -import { Types } from "../server/Message"; - -export class IconField extends BasicField<string> { -    constructor(data: string = "", id?: FieldId, save: boolean = true) { -        super(data, save, id); -    } - -    ToScriptString(): string { -        return `new IconField("${this.Data}")`; -    } - -    Copy() { -        return new IconField(this.Data); -    } - -    ToJson() { -        return { -            type: Types.Icon, -            data: this.Data, -            id: this.Id -        }; -    } -}
\ No newline at end of file diff --git a/src/fields/ImageField.ts b/src/fields/ImageField.ts deleted file mode 100644 index bce20f242..000000000 --- a/src/fields/ImageField.ts +++ /dev/null @@ -1,29 +0,0 @@ -import { BasicField } from "./BasicField"; -import { Field, FieldId } from "./Field"; -import { Types } from "../server/Message"; - -export class ImageField extends BasicField<URL> { -    constructor(data: URL | undefined = undefined, id?: FieldId, save: boolean = true) { -        super(data === undefined ? new URL("http://cs.brown.edu/~bcz/bob_fettucine.jpg") : data, save, id); -    } - -    toString(): string { -        return this.Data.href; -    } - -    ToScriptString(): string { -        return `new ImageField("${this.Data}")`; -    } - -    Copy(): Field { -        return new ImageField(this.Data); -    } - -    ToJson() { -        return { -            type: Types.Image, -            data: this.Data.href, -            id: this.Id -        }; -    } -}
\ No newline at end of file diff --git a/src/fields/InkField.ts b/src/fields/InkField.ts deleted file mode 100644 index 2eacd7d0c..000000000 --- a/src/fields/InkField.ts +++ /dev/null @@ -1,53 +0,0 @@ -import { BasicField } from "./BasicField"; -import { Types } from "../server/Message"; -import { FieldId } from "./Field"; -import { observable, ObservableMap } from "mobx"; - -export enum InkTool { -    None, -    Pen, -    Highlighter, -    Eraser -} -export interface StrokeData { -    pathData: Array<{ x: number, y: number }>; -    color: string; -    width: string; -    tool: InkTool; -    page: number; -} -export type StrokeMap = Map<string, StrokeData>; - -export class InkField extends BasicField<StrokeMap> { -    constructor(data: StrokeMap = new Map, id?: FieldId, save: boolean = true) { -        super(data, save, id); -    } - -    ToScriptString(): string { -        return `new InkField("${this.Data}")`; -    } - -    Copy() { -        return new InkField(this.Data); -    } - -    ToJson() { -        return { -            type: Types.Ink, -            data: this.Data, -            id: this.Id, -        }; -    } - -    UpdateFromServer(data: any) { -        this.data = new ObservableMap(data); -    } - -    static FromJson(id: string, data: any): InkField { -        let map: StrokeMap = new Map<string, StrokeData>(); -        Object.keys(data).forEach(key => { -            map.set(key, data[key]); -        }); -        return new InkField(map, id, false); -    } -}
\ No newline at end of file diff --git a/src/fields/Key.ts b/src/fields/Key.ts deleted file mode 100644 index 57e2dadf0..000000000 --- a/src/fields/Key.ts +++ /dev/null @@ -1,50 +0,0 @@ -import { Field, FieldId } from "./Field"; -import { Utils } from "../Utils"; -import { observable } from "mobx"; -import { Types } from "../server/Message"; -import { Server } from "../client/Server"; - -export class Key extends Field { -    private name: string; - -    get Name(): string { -        return this.name; -    } - -    constructor(name: string, id?: string, save: boolean = true) { -        super(id || Utils.GenerateDeterministicGuid(name)); - -        this.name = name; -        if (save) { -            Server.UpdateField(this); -        } -    } - -    UpdateFromServer(data: string) { -        this.name = data; -    } - -    TrySetValue(value: any): boolean { -        throw new Error("Method not implemented."); -    } - -    GetValue() { -        return this.Name; -    } - -    Copy(): Field { -        return this; -    } - -    ToScriptString(): string { -        return name; -    } - -    ToJson() { -        return { -            type: Types.Key, -            data: this.name, -            id: this.Id -        }; -    } -}
\ No newline at end of file diff --git a/src/fields/KeyStore.ts b/src/fields/KeyStore.ts deleted file mode 100644 index a347f8bcf..000000000 --- a/src/fields/KeyStore.ts +++ /dev/null @@ -1,67 +0,0 @@ -import { Key } from "./Key"; - -export namespace KeyStore { -    export const Prototype = new Key("Prototype"); -    export const X = new Key("X"); -    export const Y = new Key("Y"); -    export const Page = new Key("Page"); -    export const Title = new Key("Title"); -    export const Author = new Key("Author"); -    export const PanX = new Key("PanX"); -    export const PanY = new Key("PanY"); -    export const Scale = new Key("Scale"); -    export const NativeWidth = new Key("NativeWidth"); -    export const NativeHeight = new Key("NativeHeight"); -    export const Width = new Key("Width"); -    export const Height = new Key("Height"); -    export const ZIndex = new Key("ZIndex"); -    export const Zoom = new Key("Zoom"); -    export const Data = new Key("Data"); -    export const Annotations = new Key("Annotations"); -    export const ViewType = new Key("ViewType"); -    export const Layout = new Key("Layout"); -    export const BackgroundColor = new Key("BackgroundColor"); -    export const BackgroundLayout = new Key("BackgroundLayout"); -    export const OverlayLayout = new Key("OverlayLayout"); -    export const LayoutKeys = new Key("LayoutKeys"); -    export const LayoutFields = new Key("LayoutFields"); -    export const ColumnsKey = new Key("SchemaColumns"); -    export const SchemaSplitPercentage = new Key("SchemaSplitPercentage"); -    export const Caption = new Key("Caption"); -    export const ActiveWorkspace = new Key("ActiveWorkspace"); -    export const DocumentText = new Key("DocumentText"); -    export const BrushingDocs = new Key("BrushingDocs"); -    export const LinkedToDocs = new Key("LinkedToDocs"); -    export const LinkedFromDocs = new Key("LinkedFromDocs"); -    export const LinkDescription = new Key("LinkDescription"); -    export const LinkTags = new Key("LinkTag"); -    export const Thumbnail = new Key("Thumbnail"); -    export const ThumbnailPage = new Key("ThumbnailPage"); -    export const CurPage = new Key("CurPage"); -    export const AnnotationOn = new Key("AnnotationOn"); -    export const NumPages = new Key("NumPages"); -    export const Ink = new Key("Ink"); -    export const Cursors = new Key("Cursors"); -    export const OptionalRightCollection = new Key("OptionalRightCollection"); -    export const Archives = new Key("Archives"); -    export const Workspaces = new Key("Workspaces"); -    export const IsMinimized = new Key("IsMinimized"); -    export const MinimizedDoc = new Key("MinimizedDoc"); -    export const MaximizedDoc = new Key("MaximizedDoc"); -    export const CopyDraggedItems = new Key("CopyDraggedItems"); - -    export const KeyList: Key[] = [Prototype, X, Y, Page, Title, Author, PanX, PanY, Scale, NativeWidth, NativeHeight, -        Width, Height, ZIndex, Zoom, Data, Annotations, ViewType, Layout, BackgroundColor, BackgroundLayout, OverlayLayout, LayoutKeys, -        LayoutFields, ColumnsKey, SchemaSplitPercentage, Caption, ActiveWorkspace, DocumentText, BrushingDocs, LinkedToDocs, LinkedFromDocs, -        LinkDescription, LinkTags, Thumbnail, ThumbnailPage, CurPage, AnnotationOn, NumPages, Ink, Cursors, OptionalRightCollection, -        Archives, Workspaces, IsMinimized, MinimizedDoc, MaximizedDoc, CopyDraggedItems -    ]; -    export function KeyLookup(keyid: string) { -        for (const key of KeyList) { -            if (key.Id === keyid) { -                return key; -            } -        } -        return undefined; -    } -} diff --git a/src/fields/ListField.ts b/src/fields/ListField.ts deleted file mode 100644 index e24099126..000000000 --- a/src/fields/ListField.ts +++ /dev/null @@ -1,196 +0,0 @@ -import { action, IArrayChange, IArraySplice, IObservableArray, observe, observable, Lambda } from "mobx"; -import { Server } from "../client/Server"; -import { UndoManager } from "../client/util/UndoManager"; -import { Types } from "../server/Message"; -import { BasicField } from "./BasicField"; -import { Field, FieldId } from "./Field"; -import { FieldMap } from "../client/SocketStub"; -import { ScriptField } from "./ScriptField"; - -export class ListField<T extends Field> extends BasicField<T[]> { -    private _proxies: string[] = []; -    private _scriptIds: string[] = []; -    private scripts: ScriptField[] = []; - -    constructor(data: T[] = [], scripts: ScriptField[] = [], id?: FieldId, save: boolean = true) { -        super(data, save, id); -        this.scripts = scripts; -        this.updateProxies(); -        this._scriptIds = this.scripts.map(script => script.Id); -        if (save) { -            Server.UpdateField(this); -        } -        this.observeList(); -    } - -    private _processingServerUpdate: boolean = false; - -    private observeDisposer: Lambda | undefined; -    private observeList(): void { -        if (this.observeDisposer) { -            this.observeDisposer(); -        } -        this.observeDisposer = observe(this.Data as IObservableArray<T>, (change: IArrayChange<T> | IArraySplice<T>) => { -            const target = change.object; -            this.updateProxies(); -            if (change.type === "splice") { -                this.runScripts(change.removed, false); -                UndoManager.AddEvent({ -                    undo: () => target.splice(change.index, change.addedCount, ...change.removed), -                    redo: () => target.splice(change.index, change.removedCount, ...change.added) -                }); -                this.runScripts(change.added, true); -            } else { -                this.runScripts([change.oldValue], false); -                UndoManager.AddEvent({ -                    undo: () => target[change.index] = change.oldValue, -                    redo: () => target[change.index] = change.newValue -                }); -                this.runScripts([change.newValue], true); -            } -            if (!this._processingServerUpdate) { -                Server.UpdateField(this); -            } -        }); -    } - -    private runScripts(fields: T[], added: boolean) { -        for (const script of this.scripts) { -            this.runScript(fields, script, added); -        } -    } - -    private runScript(fields: T[], script: ScriptField, added: boolean) { -        if (!this._processingServerUpdate) { -            for (const field of fields) { -                script.script.run({ field, added }); -            } -        } -    } - -    addScript(script: ScriptField) { -        this.scripts.push(script); -        this._scriptIds.push(script.Id); - -        this.runScript(this.Data, script, true); -        UndoManager.AddEvent({ -            undo: () => this.removeScript(script), -            redo: () => this.addScript(script), -        }); -        Server.UpdateField(this); -    } - -    removeScript(script: ScriptField) { -        const index = this.scripts.indexOf(script); -        if (index === -1) { -            return; -        } -        this.scripts.splice(index, 1); -        this._scriptIds.splice(index, 1); -        UndoManager.AddEvent({ -            undo: () => this.addScript(script), -            redo: () => this.removeScript(script), -        }); -        this.runScript(this.Data, script, false); -        Server.UpdateField(this); -    } - -    protected setData(value: T[]) { -        this.runScripts(this.data, false); - -        this.data = observable(value); -        this.updateProxies(); -        this.observeList(); -        this.runScripts(this.data, true); -    } - -    private updateProxies() { -        this._proxies = this.Data.map(field => field.Id); -    } - -    private arraysEqual(a: any[], b: any[]) { -        if (a === b) return true; -        if (a === null || b === null) return false; -        if (a.length !== b.length) return false; - -        // If you don't care about the order of the elements inside -        // the array, you should sort both arrays here. -        // Please note that calling sort on an array will modify that array. -        // you might want to clone your array first. - -        for (var i = 0; i < a.length; ++i) { -            if (a[i] !== b[i]) return false; -        } -        return true; -    } - -    init(callback: (field: Field) => any) { -        const fieldsPromise = Server.GetFields(this._proxies).then(action((fields: FieldMap) => { -            if (!this.arraysEqual(this._proxies, this.data.map(field => field.Id))) { -                var dataids = this.data.map(d => d.Id); -                var proxies = this._proxies.map(p => p); -                var added = this.data.length < this._proxies.length; -                var deleted = this.data.length > this._proxies.length; -                for (let i = 0; i < dataids.length && added; i++) { -                    added = proxies.indexOf(dataids[i]) !== -1; -                } -                for (let i = 0; i < this._proxies.length && deleted; i++) { -                    deleted = dataids.indexOf(proxies[i]) !== -1; -                } - -                this._processingServerUpdate = true; -                for (let i = 0; i < proxies.length && added; i++) { -                    if (dataids.indexOf(proxies[i]) === -1) { -                        this.Data.splice(i, 0, fields[proxies[i]] as T); -                    } -                } -                for (let i = dataids.length - 1; i >= 0 && deleted; i--) { -                    if (proxies.indexOf(dataids[i]) === -1) { -                        this.Data.splice(i, 1); -                    } -                } -                if (!added && !deleted) {// otherwise, just rebuild the whole list -                    this.setData(proxies.map(id => fields[id] as T)); -                } -                this._processingServerUpdate = false; -            } -        })); - -        const scriptsPromise = Server.GetFields(this._scriptIds).then((fields: FieldMap) => { -            this.scripts = this._scriptIds.map(id => fields[id] as ScriptField); -        }); - -        Promise.all([fieldsPromise, scriptsPromise]).then(() => callback(this)); -    } - -    ToScriptString(): string { -        return "new ListField([" + this.Data.map(field => field.ToScriptString()).join(", ") + "])"; -    } - -    Copy(): Field { -        return new ListField<T>(this.Data); -    } - - -    UpdateFromServer(data: { fields: string[], scripts: string[] }) { -        this._proxies = data.fields; -        this._scriptIds = data.scripts; -    } -    ToJson() { -        return { -            type: Types.List, -            data: { -                fields: this._proxies, -                scripts: this._scriptIds, -            }, -            id: this.Id -        }; -    } - -    static FromJson(id: string, data: { fields: string[], scripts: string[] }): ListField<Field> { -        let list = new ListField([], [], id, false); -        list._proxies = data.fields; -        list._scriptIds = data.scripts; -        return list; -    } -}
\ No newline at end of file diff --git a/src/fields/NumberField.ts b/src/fields/NumberField.ts deleted file mode 100644 index 7eea360c0..000000000 --- a/src/fields/NumberField.ts +++ /dev/null @@ -1,25 +0,0 @@ -import { BasicField } from "./BasicField"; -import { Types } from "../server/Message"; -import { FieldId } from "./Field"; - -export class NumberField extends BasicField<number> { -    constructor(data: number = 0, id?: FieldId, save: boolean = true) { -        super(data, save, id); -    } - -    ToScriptString(): string { -        return `new NumberField(${this.Data})`; -    } - -    Copy() { -        return new NumberField(this.Data); -    } - -    ToJson() { -        return { -            id: this.Id, -            type: Types.Number, -            data: this.Data -        }; -    } -}
\ No newline at end of file diff --git a/src/fields/PDFField.ts b/src/fields/PDFField.ts deleted file mode 100644 index 718a1a4c0..000000000 --- a/src/fields/PDFField.ts +++ /dev/null @@ -1,36 +0,0 @@ -import { BasicField } from "./BasicField"; -import { Field, FieldId } from "./Field"; -import { observable } from "mobx"; -import { Types } from "../server/Message"; - - - -export class PDFField extends BasicField<URL> { -    constructor(data: URL | undefined = undefined, id?: FieldId, save: boolean = true) { -        super(data === undefined ? new URL("http://cs.brown.edu/~bcz/bob_fettucine.jpg") : data, save, id); -    } - -    toString(): string { -        return this.Data.href; -    } - -    Copy(): Field { -        return new PDFField(this.Data); -    } - -    ToScriptString(): string { -        return `new PDFField("${this.Data}")`; -    } - -    ToJson() { -        return { -            type: Types.PDF, -            data: this.Data.href, -            id: this.Id -        }; -    } - -    @observable -    Page: Number = 1; - -}
\ No newline at end of file diff --git a/src/fields/RichTextField.ts b/src/fields/RichTextField.ts deleted file mode 100644 index f53f48ca6..000000000 --- a/src/fields/RichTextField.ts +++ /dev/null @@ -1,26 +0,0 @@ -import { BasicField } from "./BasicField"; -import { Types } from "../server/Message"; -import { FieldId } from "./Field"; - -export class RichTextField extends BasicField<string> { -    constructor(data: string = "", id?: FieldId, save: boolean = true) { -        super(data, save, id); -    } - -    ToScriptString(): string { -        return `new RichTextField(${this.Data})`; -    } - -    Copy() { -        return new RichTextField(this.Data); -    } - -    ToJson() { -        return { -            type: Types.RichText, -            data: this.Data, -            id: this.Id -        }; -    } - -}
\ No newline at end of file diff --git a/src/fields/ScriptField.ts b/src/fields/ScriptField.ts index 7f87be45d..ae532c9e2 100644 --- a/src/fields/ScriptField.ts +++ b/src/fields/ScriptField.ts @@ -1,101 +1,101 @@ -import { Field, FieldId } from "./Field"; -import { Types } from "../server/Message"; -import { CompileScript, ScriptOptions, CompiledScript } from "../client/util/Scripting"; -import { Server } from "../client/Server"; -import { Without } from "../Utils"; +// import { Field, FieldId } from "./Field"; +// import { Types } from "../server/Message"; +// import { CompileScript, ScriptOptions, CompiledScript } from "../client/util/Scripting"; +// import { Server } from "../client/Server"; +// import { Without } from "../Utils"; -export interface SerializableOptions extends Without<ScriptOptions, "capturedVariables"> { -    capturedIds: { [id: string]: string }; -} +// export interface SerializableOptions extends Without<ScriptOptions, "capturedVariables"> { +//     capturedIds: { [id: string]: string }; +// } -export interface ScriptData { -    script: string; -    options: SerializableOptions; -} +// export interface ScriptData { +//     script: string; +//     options: SerializableOptions; +// } -export class ScriptField extends Field { -    private _script?: CompiledScript; -    get script(): CompiledScript { -        return this._script!; -    } -    private options?: ScriptData; +// export class ScriptField extends Field { +//     private _script?: CompiledScript; +//     get script(): CompiledScript { +//         return this._script!; +//     } +//     private options?: ScriptData; -    constructor(script?: CompiledScript, id?: FieldId, save: boolean = true) { -        super(id); +//     constructor(script?: CompiledScript, id?: FieldId, save: boolean = true) { +//         super(id); -        this._script = script; +//         this._script = script; -        if (save) { -            Server.UpdateField(this); -        } -    } +//         if (save) { +//             Server.UpdateField(this); +//         } +//     } -    ToScriptString() { -        return "new ScriptField(...)"; -    } +//     ToScriptString() { +//         return "new ScriptField(...)"; +//     } -    GetValue() { -        return this.script; -    } +//     GetValue() { +//         return this.script; +//     } -    TrySetValue(): boolean { -        throw new Error("Script fields currently can't be modified"); -    } +//     TrySetValue(): boolean { +//         throw new Error("Script fields currently can't be modified"); +//     } -    UpdateFromServer() { -        throw new Error("Script fields currently can't be updated"); -    } +//     UpdateFromServer() { +//         throw new Error("Script fields currently can't be updated"); +//     } -    static FromJson(id: string, data: ScriptData): ScriptField { -        let field = new ScriptField(undefined, id, false); -        field.options = data; -        return field; -    } +//     static FromJson(id: string, data: ScriptData): ScriptField { +//         let field = new ScriptField(undefined, id, false); +//         field.options = data; +//         return field; +//     } -    init(callback: (res: Field) => any) { -        const options = this.options!; -        const keys = Object.keys(options.options.capturedIds); -        Server.GetFields(keys).then(fields => { -            let captured: { [name: string]: Field } = {}; -            keys.forEach(key => captured[options.options.capturedIds[key]] = fields[key]); -            const opts: ScriptOptions = { -                addReturn: options.options.addReturn, -                params: options.options.params, -                requiredType: options.options.requiredType, -                capturedVariables: captured -            }; -            const script = CompileScript(options.script, opts); -            if (!script.compiled) { -                throw new Error("Can't compile script"); -            } -            this._script = script; -            callback(this); -        }); -    } +//     init(callback: (res: Field) => any) { +//         const options = this.options!; +//         const keys = Object.keys(options.options.capturedIds); +//         Server.GetFields(keys).then(fields => { +//             let captured: { [name: string]: Field } = {}; +//             keys.forEach(key => captured[options.options.capturedIds[key]] = fields[key]); +//             const opts: ScriptOptions = { +//                 addReturn: options.options.addReturn, +//                 params: options.options.params, +//                 requiredType: options.options.requiredType, +//                 capturedVariables: captured +//             }; +//             const script = CompileScript(options.script, opts); +//             if (!script.compiled) { +//                 throw new Error("Can't compile script"); +//             } +//             this._script = script; +//             callback(this); +//         }); +//     } -    ToJson() { -        const { options, originalScript } = this.script; -        let capturedIds: { [id: string]: string } = {}; -        for (const capt in options.capturedVariables) { -            capturedIds[options.capturedVariables[capt].Id] = capt; -        } -        const opts: SerializableOptions = { -            ...options, -            capturedIds -        }; -        delete (opts as any).capturedVariables; -        return { -            id: this.Id, -            type: Types.Script, -            data: { -                script: originalScript, -                options: opts, -            }, -        }; -    } +//     ToJson() { +//         const { options, originalScript } = this.script; +//         let capturedIds: { [id: string]: string } = {}; +//         for (const capt in options.capturedVariables) { +//             capturedIds[options.capturedVariables[capt].Id] = capt; +//         } +//         const opts: SerializableOptions = { +//             ...options, +//             capturedIds +//         }; +//         delete (opts as any).capturedVariables; +//         return { +//             id: this.Id, +//             type: Types.Script, +//             data: { +//                 script: originalScript, +//                 options: opts, +//             }, +//         }; +//     } -    Copy(): Field { -        //Script fields are currently immutable, so we can fake copy them -        return this; -    } -}
\ No newline at end of file +//     Copy(): Field { +//         //Script fields are currently immutable, so we can fake copy them +//         return this; +//     } +// }
\ No newline at end of file diff --git a/src/fields/TemplateField.ts b/src/fields/TemplateField.ts new file mode 100644 index 000000000..72ae13c2e --- /dev/null +++ b/src/fields/TemplateField.ts @@ -0,0 +1,43 @@ +import { BasicField } from "./BasicField"; +import { Types } from "../server/Message"; +import { FieldId } from "./Field"; +import { Template, TemplatePosition } from "../client/views/Templates"; + + +export class TemplateField extends BasicField<Array<Template>> { +    constructor(data: Array<Template> = [], id?: FieldId, save: boolean = true) { +        super(data, save, id); +    } + +    ToScriptString(): string { +        return `new TemplateField("${this.Data}")`; +    } + +    Copy() { +        return new TemplateField(this.Data); +    } + +    ToJson() { +        let templates: Array<{ name: string, position: TemplatePosition, layout: string }> = []; +        this.Data.forEach(template => { +            templates.push({ name: template.Name, layout: template.Layout, position: template.Position }); +        }); +        return { +            type: Types.Templates, +            data: templates, +            id: this.Id, +        }; +    } + +    UpdateFromServer(data: any) { +        this.data = new Array(data); +    } + +    static FromJson(id: string, data: any): TemplateField { +        let templates: Array<Template> = []; +        data.forEach((template: { name: string, position: number, layout: string }) => { +            templates.push(new Template(template.name, template.position, template.layout)); +        }); +        return new TemplateField(templates, id, false); +    } +}
\ No newline at end of file diff --git a/src/fields/TextField.ts b/src/fields/TextField.ts deleted file mode 100644 index ddedec9b1..000000000 --- a/src/fields/TextField.ts +++ /dev/null @@ -1,25 +0,0 @@ -import { BasicField } from "./BasicField"; -import { FieldId } from "./Field"; -import { Types } from "../server/Message"; - -export class TextField extends BasicField<string> { -    constructor(data: string = "", id?: FieldId, save: boolean = true) { -        super(data, save, id); -    } - -    ToScriptString(): string { -        return `new TextField("${this.Data}")`; -    } - -    Copy() { -        return new TextField(this.Data); -    } - -    ToJson() { -        return { -            type: Types.Text, -            data: this.Data, -            id: this.Id -        }; -    } -}
\ No newline at end of file diff --git a/src/fields/TupleField.ts b/src/fields/TupleField.ts deleted file mode 100644 index 347f1fa05..000000000 --- a/src/fields/TupleField.ts +++ /dev/null @@ -1,59 +0,0 @@ -import { action, IArrayChange, IArraySplice, IObservableArray, observe, observable, Lambda } from "mobx"; -import { Server } from "../client/Server"; -import { UndoManager } from "../client/util/UndoManager"; -import { Types } from "../server/Message"; -import { BasicField } from "./BasicField"; -import { Field, FieldId } from "./Field"; - -export class TupleField<T, U> extends BasicField<[T, U]> { -    constructor(data: [T, U], id?: FieldId, save: boolean = true) { -        super(data, save, id); -        if (save) { -            Server.UpdateField(this); -        } -        this.observeTuple(); -    } - -    private observeDisposer: Lambda | undefined; -    private observeTuple(): void { -        this.observeDisposer = observe(this.Data as (T | U)[] as IObservableArray<T | U>, (change: IArrayChange<T | U> | IArraySplice<T | U>) => { -            if (change.type === "update") { -                UndoManager.AddEvent({ -                    undo: () => this.Data[change.index] = change.oldValue, -                    redo: () => this.Data[change.index] = change.newValue -                }); -                Server.UpdateField(this); -            } else { -                throw new Error("Why are you messing with the length of a tuple, huh?"); -            } -        }); -    } - -    protected setData(value: [T, U]) { -        if (this.observeDisposer) { -            this.observeDisposer(); -        } -        this.data = observable(value) as (T | U)[] as [T, U]; -        this.observeTuple(); -    } - -    UpdateFromServer(values: [T, U]) { -        this.setData(values); -    } - -    ToScriptString(): string { -        return `new TupleField([${this.Data[0], this.Data[1]}])`; -    } - -    Copy(): Field { -        return new TupleField<T, U>(this.Data); -    } - -    ToJson() { -        return { -            type: Types.Tuple, -            data: this.Data, -            id: this.Id -        }; -    } -}
\ No newline at end of file diff --git a/src/fields/VideoField.ts b/src/fields/VideoField.ts deleted file mode 100644 index 838b811b1..000000000 --- a/src/fields/VideoField.ts +++ /dev/null @@ -1,30 +0,0 @@ -import { BasicField } from "./BasicField"; -import { Field, FieldId } from "./Field"; -import { Types } from "../server/Message"; - -export class VideoField extends BasicField<URL> { -    constructor(data: URL | undefined = undefined, id?: FieldId, save: boolean = true) { -        super(data === undefined ? new URL("http://techslides.com/demos/sample-videos/small.mp4") : data, save, id); -    } - -    toString(): string { -        return this.Data.href; -    } - -    ToScriptString(): string { -        return `new VideoField("${this.Data}")`; -    } - -    Copy(): Field { -        return new VideoField(this.Data); -    } - -    ToJson() { -        return { -            type: Types.Video, -            data: this.Data.href, -            id: this.Id -        }; -    } - -}
\ No newline at end of file diff --git a/src/fields/WebField.ts b/src/fields/WebField.ts deleted file mode 100644 index 8b276a552..000000000 --- a/src/fields/WebField.ts +++ /dev/null @@ -1,30 +0,0 @@ -import { BasicField } from "./BasicField"; -import { Field, FieldId } from "./Field"; -import { Types } from "../server/Message"; - -export class WebField extends BasicField<URL> { -    constructor(data: URL | undefined = undefined, id?: FieldId, save: boolean = true) { -        super(data === undefined ? new URL("https://crossorigin.me/" + "https://cs.brown.edu/") : data, save, id); -    } - -    toString(): string { -        return this.Data.href; -    } - -    ToScriptString(): string { -        return `new WebField("${this.Data}")`; -    } - -    Copy(): Field { -        return new WebField(this.Data); -    } - -    ToJson() { -        return { -            type: Types.Web, -            data: this.Data.href, -            id: this.Id -        }; -    } - -}
\ No newline at end of file | 
