@genialis/resolwe
Advanced tools
Comparing version 3.1.1 to 3.1.2
@@ -224,2 +224,3 @@ /// <reference types="lodash" /> | ||
process_output_schema: any; | ||
process_slug: string; | ||
process_name: string; | ||
@@ -226,0 +227,0 @@ slug: string; |
@@ -54,2 +54,2 @@ "use strict"; | ||
//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["../src/api/types/rest.ts"],"names":[],"mappings":";AAAA;;;;GAIG;;AAGH,0BAA4B;AAyB5B,6BAAuC,QAA2B;IAC9D,MAAM,CAAC,QAAQ,CAAC,cAAc,CAAC,SAAS,CAAC,CAAC;AAC9C,CAAC;AAFD,kDAEC;AAsBY,QAAA,gBAAgB,GAAoB,OAAO,CAAC;AAC5C,QAAA,gBAAgB,GAAoB,OAAO,CAAC;AAC5C,QAAA,eAAe,GAAmB,MAAM,CAAC;AACzC,QAAA,iBAAiB,GAAqB,MAAM,CAAC;AAC7C,QAAA,cAAc,GAAkB,KAAK,CAAC;AACtC,QAAA,mBAAmB,GAAuB,UAAU,CAAC;AACrD,QAAA,eAAe,GAAmB,MAAM,CAAC;AAUzC,QAAA,sBAAsB,GAAyB,QAAQ,CAAC;AACxD,QAAA,qBAAqB,GAAwB,OAAO,CAAC;AACrD,QAAA,oBAAoB,GAAuB,MAAM,CAAC;AAkDlD,QAAA,uBAAuB,GAA0B,KAAK,CAAC;AACvD,QAAA,0BAA0B,GAA6B,KAAK,CAAC;AAC7D,QAAA,wBAAwB,GAA2B,KAAK,CAAC;AAyJzD,QAAA,qBAAqB,GAAwB,IAAI,CAAC;AAClD,QAAA,qBAAqB,GAAwB,IAAI,CAAC;AAClD,QAAA,mBAAmB,GAAsB,IAAI,CAAC;AAC9C,QAAA,sBAAsB,GAAyB,IAAI,CAAC;AACpD,QAAA,gBAAgB,GAAmB,IAAI,CAAC;AACxC,QAAA,iBAAiB,GAAoB,IAAI,CAAC;AAC1C,QAAA,iBAAiB,GAAoB,IAAI,CAAC;AAoCvD,gBAAuB,MAA0C;IAC7D,MAAM,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,UAAU,EAAE,QAAQ,EAAE,SAAS,EAAE,cAAc,EAAE,cAAc,EAAE,OAAO,EAAE,QAAQ,EAAE,0BAA0B,CAAC,EACzH,UAAC,QAAQ,IAAK,OAAA,MAAM,CAAC,cAAc,CAAC,QAAQ,CAAC,EAA/B,CAA+B,CAChD,CAAC;AACN,CAAC;AAJD,wBAIC;AAiLD,sBAA6B,MAA0C;IACnE,wEAAwE;IACxE,2CAA2C;IAC3C,MAAM,CAAC,MAAM,CAAC,cAAc,CAAC,aAAa,CAAC;QACvC,MAAM,CAAC,cAAc,CAAC,UAAU,CAAC;QACjC,MAAM,CAAC,cAAc,CAAC,MAAM,CAAC;QAC7B,CAAC,MAAM,CAAC,cAAc,CAAC,sBAAsB,CAAC,CAAC;AACvD,CAAC;AAPD,oCAOC;AAUD,sBAA6B,MAA0C;IACnE,MAAM,CAAC,MAAM,CAAC,cAAc,CAAC,aAAa,CAAC;QACvC,MAAM,CAAC,cAAc,CAAC,UAAU,CAAC;QACjC,MAAM,CAAC,cAAc,CAAC,MAAM,CAAC;QAC7B,MAAM,CAAC,cAAc,CAAC,sBAAsB,CAAC,CAAC;AACtD,CAAC;AALD,oCAKC","file":"api/types/rest.js","sourcesContent":["/*\n * Type definitions\n *\n * Here is defined everything the API returns.\n */\n\nimport * as Rx from 'rx';\nimport * as _ from 'lodash';\n\nimport Dictionary = _.Dictionary;\nimport NumericDictionary = _.NumericDictionary;\n\n\n// ------------------------------------------------------------------\n// Query\n\nexport interface Query {\n    limit?: number;\n    offset?: number;\n    ordering?: string; // '-field1,-field2,field3'\n    fields?: string;\n    [propertyName: string]: any;\n}\n\nexport interface QueryObject extends Query {\n    hydrate_data?: void;\n}\n\nexport interface QueryObjectHydrateData extends Query {\n    hydrate_data: '1';\n}\n\nexport function isResponsePaginated<T>(response: T | { results: T}): response is { results: T } {\n    return response.hasOwnProperty('results');\n}\n\n// LimitOffsetPagination\nexport interface PaginatedResponse<T> {\n    count: number;\n    next: string;\n    previous: string;\n    results: T[];\n}\n\n\n// ------------------------------------------------------------------\n// Permissions\n\nexport type OwnerPermission = 'owner';\nexport type SharePermission = 'share';\nexport type EditPermission = 'edit';\nexport type DeletePermission = 'edit'; // not a typo (API doesn't support delete permission)\nexport type AddPermission = 'add';\nexport type DownloadPermission = 'download';\nexport type ViewPermission = 'view';\n\nexport const OWNER_PERMISSION: OwnerPermission = 'owner';\nexport const SHARE_PERMISSION: SharePermission = 'share';\nexport const EDIT_PERMISSION: EditPermission = 'edit';\nexport const DELETE_PERMISSION: DeletePermission = 'edit';\nexport const ADD_PERMISSION: AddPermission = 'add';\nexport const DOWNLOAD_PERMISSION: DownloadPermission = 'download';\nexport const VIEW_PERMISSION: ViewPermission = 'view';\n\nexport type Permission = OwnerPermission | SharePermission | EditPermission | DeletePermission | AddPermission |\n    DownloadPermission | ViewPermission;\n\n\nexport type PublicPermissionType = 'public';\nexport type GroupPermissionType = 'group';\nexport type UserPermissionType = 'user';\n\nexport const PUBLIC_PERMISSION_TYPE: PublicPermissionType = 'public';\nexport const GROUP_PERMISSION_TYPE: GroupPermissionType = 'group';\nexport const USER_PERMISSION_TYPE: UserPermissionType = 'user';\n\nexport type PermissionType = PublicPermissionType | GroupPermissionType | UserPermissionType;\n\nexport interface ItemPermissionsOf<T> {\n    type: PermissionType;\n    permissions: T[];\n    id?: number;\n    name?: string;\n}\n\nexport type ItemPermissions = ItemPermissionsOf<Permission>;\n\nexport interface SetPermissionsRequest {\n    public?: {\n        add?: Permission[],\n        remove?: Permission[]\n    };\n    groups?: {\n        add?: NumericDictionary<Permission[]> | Dictionary<Permission[]>\n        remove?: NumericDictionary<Permission[]> | Dictionary<Permission[]>\n    };\n    users?: {\n        add?: NumericDictionary<Permission[]> | Dictionary<Permission[]>\n        remove?: NumericDictionary<Permission[]> | Dictionary<Permission[]>\n    };\n    share_content?: '0' | '1';\n}\n\n\n// ------------------------------------------------------------------\n// Contributor\n\nexport interface Contributor {\n    id: number;\n    username: string;\n    first_name: string;\n    last_name: string;\n}\n\n\n// ------------------------------------------------------------------\n// Process\n\nexport type ProcessPermissions = ViewPermission | SharePermission;\n\nexport type RawProcessPersistence = 'RAW';\nexport type CachedProcessPersistence = 'CAC';\nexport type TempProcessPersistence = 'TMP';\n\nexport const RAW_PROCESS_PERSISTENCE: RawProcessPersistence = 'RAW';\nexport const CACHED_PROCESS_PERSISTENCE: CachedProcessPersistence = 'CAC';\nexport const TEMP_PROCESS_PERSISTENCE: TempProcessPersistence = 'TMP';\n\nexport type ProcessPersistence = RawProcessPersistence | CachedProcessPersistence | TempProcessPersistence;\n\nexport interface Process {\n    id: number;\n    slug: string;\n    name: string;\n    created: string;\n    modified: string;\n    version: number;\n    type: string;\n    category: string;\n    persistence: ProcessPersistence;\n    description: string;\n    input_schema: any;\n    output_schema: any;\n    run: any;\n    contributor: Contributor;\n    current_user_permissions: ItemPermissionsOf<ProcessPermissions>[];\n}\n\n// ------------------------------------------------------------------\n// Relation\n\n// Relation entity\nexport interface RelationEntity {\n    entity: number;\n    position: string;\n}\n\nexport interface Relation {\n    id: number;\n    slug: string;\n    created: string;\n    modified: string;\n    type: string;\n    collection: number;\n    entities: RelationEntity[];\n    positions: string[];\n    label: string;\n    contributor: Contributor;\n\n}\n\n// ------------------------------------------------------------------\n// DescriptorSchema\n\n// Schema\nexport interface ChoiceMap {\n    value: string;\n    label: string;\n}\n\nexport interface FieldSchema {\n    disabled?: boolean | string;\n    required?: boolean;\n    collapsed?: boolean;\n    hidden?: boolean | string;\n    default?: any;\n    choices?: ChoiceMap[];\n    allow_custom_choice?: boolean;\n    validate_regex?: string;\n    slug?: {\n        source?: string;\n        uniqueValidator?: (slug: string) => Rx.Observable<boolean>;\n    };\n    type: string;\n    name: string;\n    label: string;\n    group?: Schema;\n}\n\nexport type Schema = FieldSchema[];\n\n\n// DescriptorSchema\nexport type DescriptorSchemaPermissions = ViewPermission | EditPermission | SharePermission;\n\nexport interface DescriptorSchemaBase {\n    id: number;\n    created: string;\n    modified: string;\n    slug: string;\n    name: string;\n    version: number;\n    schema: Schema;\n    contributor: Contributor;\n}\n\nexport interface DescriptorSchema extends DescriptorSchemaBase {\n    current_user_permissions: ItemPermissionsOf<DescriptorSchemaPermissions>[];\n}\n\n\n// ------------------------------------------------------------------\n// Scatter Plot Json\n\n// ScatterPlotJson.RootObject is a type of process output. Processes (i.e. Rose2)\n// save it to data.output.scatter_plot.\nexport namespace ScatterPlotJson {\n\n    export interface RootObject { // This is the actual type of the json output\n        points: Points;\n        meta?: Meta;\n        annotations?: Annotation[];\n    }\n\n    export interface Points {\n        x_axis: number[];\n        y_axis: number[];\n        items?: any[];\n    }\n\n    export interface Meta {\n        x_label?: string;\n        y_label?: string;\n        text?: string;\n        chr_pos?: string[];\n    }\n\n    export type Annotation = AnnotationLineGeneral | AnnotationLineVertical | AnnotationLineHorizontal;\n\n    export interface AnnotationLineGeneral {\n        type: 'line';\n        x1: number;\n        x2: number;\n        y1: number;\n        y2: number;\n    }\n    export interface AnnotationLineVertical {\n        type: 'line_vertical';\n        x: number;\n    }\n    export interface AnnotationLineHorizontal {\n        type: 'line_horizontal';\n        y: number;\n    }\n}\n\n// ------------------------------------------------------------------\n// Data\n\nexport type DataPermissions = ViewPermission | EditPermission | SharePermission | DownloadPermission;\n\nexport type UploadingDataStatus = 'UP';\nexport type ResolvingDataStatus = 'RE';\nexport type WaitingDataStatus = 'WT';\nexport type ProcessingDataStatus = 'PR';\nexport type DoneDataStatus = 'OK';\nexport type ErrorDataStatus = 'ER';\nexport type DirtyDataStatus = 'DR';\n\nexport const UPLOADING_DATA_STATUS: UploadingDataStatus = 'UP';\nexport const RESOLVING_DATA_STATUS: ResolvingDataStatus = 'RE';\nexport const WAITING_DATA_STATUS: WaitingDataStatus = 'WT';\nexport const PROCESSING_DATA_STATUS: ProcessingDataStatus = 'PR';\nexport const DONE_DATA_STATUS: DoneDataStatus = 'OK';\nexport const ERROR_DATA_STATUS: ErrorDataStatus = 'ER';\nexport const DIRTY_DATA_STATUS: DirtyDataStatus = 'DR';\n\nexport type DataStatus = UploadingDataStatus | ResolvingDataStatus | WaitingDataStatus | ProcessingDataStatus |\n    DoneDataStatus | ErrorDataStatus | DirtyDataStatus;\n\nexport interface DataBase {\n    id: number;\n    created: string;\n    modified: string;\n    started: string;\n    finished: string;\n    checksum: string;\n    status: DataStatus;\n    process_progress: number;\n    process_rc: number;\n    process_info: string[];\n    process_warning: string[];\n    process_error: string[];\n    process_type: string;\n    process_input_schema: any;\n    process_output_schema: any;\n    process_name: string;\n    slug: string;\n    name: string;\n    input: any;\n    output: any;\n    descriptor_schema: DescriptorSchemaBase;\n    descriptor: any;\n    contributor: Contributor;\n    process: number;\n}\n\nexport interface Data extends DataBase {\n    current_user_permissions: ItemPermissionsOf<DataPermissions>[];\n}\n\nexport function isData(object: CollectionBase | SampleBase | Data): object is Data {\n    return _.all(['checksum', 'status', 'process', 'process_name', 'process_type', 'input', 'output', 'current_user_permissions'],\n        (property) => object.hasOwnProperty(property)\n    );\n}\n\n// ------------------------------------------------------------------\n// data:differentialexpression:\n\nexport interface DataDifferentialExpression extends Data {\n    output: {\n        de_file: { file: string, size: number };\n        raw: { file: string, size: number };\n        de_json: number;\n        source: string;\n        species: string;\n    };\n}\n\n// ------------------------------------------------------------------\n// data:geneset:\n\nexport interface DataGenesetOutput {\n    geneset: { file: string, size: number };\n    geneset_json: number; // => DataGenesetStorage\n    source: string;\n    species: string;\n}\n\nexport interface DataGeneset extends Data {\n    output: DataGenesetOutput;\n}\n\nexport interface DataGenesetStorage extends Storage {\n    json: {\n        genes: string[];\n    };\n}\n\n// ------------------------------------------------------------------\n// data:geneset:venn:\n\nexport interface DataGenesetVennOutput extends DataGenesetOutput {\n    venn: number; // => DataGenesetVennStorage\n}\n\nexport interface DataGenesetVenn extends DataGeneset {\n    output: DataGenesetVennOutput;\n}\n\nexport interface DataGenesetVennStorage extends Storage {\n    json: {\n        parents: Array<{\n            id: number;\n            name: string;\n            genes: string[]; // geneset_json . genes\n        }>;\n    };\n}\n\n// ------------------------------------------------------------------\n// data:goea: Gene Ontology\n\nexport interface DataGOEnrichmentAnalysis extends Data {\n    output: {\n        terms: number; // => DataGOEnrichmentAnalysisStorage\n        source: string;\n        species: string;\n    };\n}\n\nexport type GOEnrichmentAspect = GOEnrichmentNode[];\nexport interface GOEnrichmentJson {\n    total_genes: number;\n    gene_associations: {\n        [goTermId: string]: string[]; // term_id => gene_ids\n    };\n    tree: {\n        [aspectSlug: string]: GOEnrichmentAspect, // \"BP\" | \"CC\" | \"MF\"\n    };\n}\n\nexport interface GOEnrichmentNode {\n    gene_ids: string[];\n    term_name: string;\n    term_id: string;\n    pval: number;\n    score: number;\n    matched: number; // Number of found elements in a single node.\n    total: number; // Total number of elements (including children nodes) in a single node.\n    children?: GOEnrichmentNode[];\n\n    // Added by frontend:\n    depth?: number; // Numerical representation of the level of depth. Used for offsetting the term column.\n    source?: string;\n    species?: string;\n    score_percentage?: number; // Percentage of max score within GOEnrichmentAspect.\n    gene_associations?: string[]; // Plucked from GOEnrichmentJson.gene_associations.\n    collapsed?: boolean; // Boolean representation if the selected item is hidden.\n}\n\nexport interface DataGOEnrichmentAnalysisStorage extends Storage {\n    json: GOEnrichmentJson;\n}\n\nexport interface DataGOEnrichmentAnalysisInput {\n    pval_threshold: number;\n    genes: string[];\n    source: string;\n    species: string;\n    ontology: number;\n    gaf: number;\n}\n\n// ------------------------------------------------------------------\n// data:gaf: GAF annotation\n\nexport interface DataGafAnnotation extends Data {\n    output: {\n        source: string;\n        species: string;\n        gaf: { file: string, size: number };\n        gaf_obj: { file: string, size: number };\n    };\n}\n\n// ------------------------------------------------------------------\n// data:varianttable:\n\nexport interface DataVariantTable extends Data {\n    output: {\n        variant_table: number; // => DataVariantTableStorage\n    };\n}\n\nexport type DataVariantTableJsonValueColumn = string; // Example: MSH6_exon5_F1/2\nexport type DataVariantTableJsonDelimitedColumn = string; // Example: DP4=46,41,11,16;SB=4\nexport type DataVariantTableJsonUrlsColumn = [string, string][]; // Example: [['Gene', 'http://www.ncbi.nlm.nih.gov/gene/?term=gene']]\nexport type DataVariantTableJsonColumn = DataVariantTableJsonValueColumn |\n                                         DataVariantTableJsonDelimitedColumn |\n                                         DataVariantTableJsonUrlsColumn;\nexport interface DataVariantTableRow {\n    columns: DataVariantTableJsonColumn[];\n    pos: string;\n}\n\nexport interface DataVariantTableJson { // api-typecheck:amplicon_table_output.json.gz\n    column_types: Array<'value' | 'delimited' | 'urls'>;\n    headers: string[];\n    labels: string[];\n    data: DataVariantTableRow[];\n}\n\nexport interface DataVariantTableStorage extends Storage {\n    json: DataVariantTableJson;\n}\n\n// ------------------------------------------------------------------\n// Collection\n\nexport type CollectionPermissions = ViewPermission | EditPermission | SharePermission |\n    DownloadPermission | AddPermission;\n\nexport interface CollectionBase {\n    id: number;\n    created: string;\n    modified: string;\n    slug: string;\n    name: string;\n    description: string;\n    settings: any;\n    descriptor_schema: DescriptorSchemaBase;\n    descriptor: any;\n    contributor: Contributor;\n    current_user_permissions: ItemPermissionsOf<CollectionPermissions>[];\n}\n\nexport interface Collection extends CollectionBase {\n    data: number[];\n}\n\nexport function isCollection(object: CollectionBase | SampleBase | Data): object is Collection | CollectionHydrateData {\n    // CollectionBase doesn't contain `data` property in it's interface, but\n    // Collection and CollectionHydrateData do.\n    return object.hasOwnProperty('description') &&\n        object.hasOwnProperty('settings') &&\n        object.hasOwnProperty('data') &&\n        !object.hasOwnProperty('descriptor_completed');\n}\n\nexport interface CollectionHydrateData extends CollectionBase {\n    data: DataBase[];\n}\n\nexport interface SampleBase extends CollectionBase {\n    descriptor_completed: boolean;\n}\n\nexport function isSampleBase(object: CollectionBase | SampleBase | Data): object is SampleBase {\n    return object.hasOwnProperty('description') &&\n        object.hasOwnProperty('settings') &&\n        object.hasOwnProperty('data') &&\n        object.hasOwnProperty('descriptor_completed');\n}\n\nexport interface Sample extends Collection, SampleBase {\n    descriptor_completed: true;\n}\n\nexport interface SampleHydrateData extends CollectionHydrateData, SampleBase {\n}\n\nexport interface Presample extends Collection, SampleBase {\n    descriptor_completed: false;\n}\n\nexport interface PresampleHydrateData extends CollectionHydrateData, SampleBase {\n    descriptor_completed: false;\n}\n\n\n// ------------------------------------------------------------------\n// Storage\n\nexport interface Storage {\n    id: number;\n    slug: string;\n    name: string;\n    data: number;\n    json: any;\n    contributor: Contributor;\n    created: string;\n    modified: string;\n}\n\nexport interface SampleClustering { // api-typecheck:sample_cluster_data.json.gz\n    sample_ids: _.Dictionary<{ id: number }>;\n    order: number[];\n    linkage: number[][]; // [[node1, node2, distance, number of samples]]\n    zero_sample_ids: number[]; // sample ids with no expressions\n    zero_gene_symbols: string[]; // gene symbols with no expressions\n    missing_gene_symbols: string[];\n}\n\nexport interface GeneClustering { // api-typecheck:gene_cluster_data.json.gz\n    gene_symbols: _.Dictionary<{ gene: string }>;\n    order: number[];\n    linkage: number[][]; // [[node1, node2, distance, number of genes]]\n    zero_sample_ids: number[]; // sample ids with no expressions\n    zero_gene_symbols: string[]; // gene symbols with no expressions\n    missing_gene_symbols: string[];\n}\n\nexport interface PCA { // api-typecheck:pca_plot_ncbi.json.gz\n    explained_variance_ratios: number[];\n    all_explained_variance_ratios: number[];\n    all_components: [string, number][][];\n    components: [string, number][][];\n    zero_gene_symbols: string[]; // gene ids with no expressions\n    flot: {\n        xlabel: string;\n        ylabel: string;\n        data: number[][];\n        sample_ids: string[];\n    };\n}\n\nexport interface QCStorage extends Storage {\n    json: {\n        status: 'PASS' | 'FAIL' | 'WARNING',\n        message: string,\n    };\n}\n\n\n// ------------------------------------------------------------------\n// User\n\nexport interface User {\n    id: number;\n    username: string;\n    email: string;\n    first_name: string;\n    last_name: string;\n    job_title: string;\n    company: string;\n    department: string;\n    location: string;\n    lab: string;\n    phone_number: string;\n    last_login: string;\n    date_joined: string;\n}\n\nexport interface LoginResponse {\n    key: string;\n}\n\nexport interface LogoutResponse {\n}\n\nexport interface CreateAccountInformation {\n    username: string;\n    password: string;\n    email: string;\n    first_name: string;\n    last_name: string;\n    job_title?: string;\n    company?: string;\n    department?: string;\n    location?: string;\n    lab?: string;\n    phone_number?: string;\n    newsletter?: boolean;\n    community?: string;\n}\n\nexport interface ActivateAccountResponse {\n    username: string;\n}\n\n\n// ------------------------------------------------------------------\n// File\n\nexport interface Download {\n    data: string;\n}\n"]} | ||
//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["../src/api/types/rest.ts"],"names":[],"mappings":";AAAA;;;;GAIG;;AAGH,0BAA4B;AAyB5B,6BAAuC,QAA2B;IAC9D,MAAM,CAAC,QAAQ,CAAC,cAAc,CAAC,SAAS,CAAC,CAAC;AAC9C,CAAC;AAFD,kDAEC;AAsBY,QAAA,gBAAgB,GAAoB,OAAO,CAAC;AAC5C,QAAA,gBAAgB,GAAoB,OAAO,CAAC;AAC5C,QAAA,eAAe,GAAmB,MAAM,CAAC;AACzC,QAAA,iBAAiB,GAAqB,MAAM,CAAC;AAC7C,QAAA,cAAc,GAAkB,KAAK,CAAC;AACtC,QAAA,mBAAmB,GAAuB,UAAU,CAAC;AACrD,QAAA,eAAe,GAAmB,MAAM,CAAC;AAUzC,QAAA,sBAAsB,GAAyB,QAAQ,CAAC;AACxD,QAAA,qBAAqB,GAAwB,OAAO,CAAC;AACrD,QAAA,oBAAoB,GAAuB,MAAM,CAAC;AAkDlD,QAAA,uBAAuB,GAA0B,KAAK,CAAC;AACvD,QAAA,0BAA0B,GAA6B,KAAK,CAAC;AAC7D,QAAA,wBAAwB,GAA2B,KAAK,CAAC;AAyJzD,QAAA,qBAAqB,GAAwB,IAAI,CAAC;AAClD,QAAA,qBAAqB,GAAwB,IAAI,CAAC;AAClD,QAAA,mBAAmB,GAAsB,IAAI,CAAC;AAC9C,QAAA,sBAAsB,GAAyB,IAAI,CAAC;AACpD,QAAA,gBAAgB,GAAmB,IAAI,CAAC;AACxC,QAAA,iBAAiB,GAAoB,IAAI,CAAC;AAC1C,QAAA,iBAAiB,GAAoB,IAAI,CAAC;AAqCvD,gBAAuB,MAA0C;IAC7D,MAAM,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,UAAU,EAAE,QAAQ,EAAE,SAAS,EAAE,cAAc,EAAE,cAAc,EAAE,OAAO,EAAE,QAAQ,EAAE,0BAA0B,CAAC,EACzH,UAAC,QAAQ,IAAK,OAAA,MAAM,CAAC,cAAc,CAAC,QAAQ,CAAC,EAA/B,CAA+B,CAChD,CAAC;AACN,CAAC;AAJD,wBAIC;AAiLD,sBAA6B,MAA0C;IACnE,wEAAwE;IACxE,2CAA2C;IAC3C,MAAM,CAAC,MAAM,CAAC,cAAc,CAAC,aAAa,CAAC;QACvC,MAAM,CAAC,cAAc,CAAC,UAAU,CAAC;QACjC,MAAM,CAAC,cAAc,CAAC,MAAM,CAAC;QAC7B,CAAC,MAAM,CAAC,cAAc,CAAC,sBAAsB,CAAC,CAAC;AACvD,CAAC;AAPD,oCAOC;AAUD,sBAA6B,MAA0C;IACnE,MAAM,CAAC,MAAM,CAAC,cAAc,CAAC,aAAa,CAAC;QACvC,MAAM,CAAC,cAAc,CAAC,UAAU,CAAC;QACjC,MAAM,CAAC,cAAc,CAAC,MAAM,CAAC;QAC7B,MAAM,CAAC,cAAc,CAAC,sBAAsB,CAAC,CAAC;AACtD,CAAC;AALD,oCAKC","file":"api/types/rest.js","sourcesContent":["/*\n * Type definitions\n *\n * Here is defined everything the API returns.\n */\n\nimport * as Rx from 'rx';\nimport * as _ from 'lodash';\n\nimport Dictionary = _.Dictionary;\nimport NumericDictionary = _.NumericDictionary;\n\n\n// ------------------------------------------------------------------\n// Query\n\nexport interface Query {\n    limit?: number;\n    offset?: number;\n    ordering?: string; // '-field1,-field2,field3'\n    fields?: string;\n    [propertyName: string]: any;\n}\n\nexport interface QueryObject extends Query {\n    hydrate_data?: void;\n}\n\nexport interface QueryObjectHydrateData extends Query {\n    hydrate_data: '1';\n}\n\nexport function isResponsePaginated<T>(response: T | { results: T}): response is { results: T } {\n    return response.hasOwnProperty('results');\n}\n\n// LimitOffsetPagination\nexport interface PaginatedResponse<T> {\n    count: number;\n    next: string;\n    previous: string;\n    results: T[];\n}\n\n\n// ------------------------------------------------------------------\n// Permissions\n\nexport type OwnerPermission = 'owner';\nexport type SharePermission = 'share';\nexport type EditPermission = 'edit';\nexport type DeletePermission = 'edit'; // not a typo (API doesn't support delete permission)\nexport type AddPermission = 'add';\nexport type DownloadPermission = 'download';\nexport type ViewPermission = 'view';\n\nexport const OWNER_PERMISSION: OwnerPermission = 'owner';\nexport const SHARE_PERMISSION: SharePermission = 'share';\nexport const EDIT_PERMISSION: EditPermission = 'edit';\nexport const DELETE_PERMISSION: DeletePermission = 'edit';\nexport const ADD_PERMISSION: AddPermission = 'add';\nexport const DOWNLOAD_PERMISSION: DownloadPermission = 'download';\nexport const VIEW_PERMISSION: ViewPermission = 'view';\n\nexport type Permission = OwnerPermission | SharePermission | EditPermission | DeletePermission | AddPermission |\n    DownloadPermission | ViewPermission;\n\n\nexport type PublicPermissionType = 'public';\nexport type GroupPermissionType = 'group';\nexport type UserPermissionType = 'user';\n\nexport const PUBLIC_PERMISSION_TYPE: PublicPermissionType = 'public';\nexport const GROUP_PERMISSION_TYPE: GroupPermissionType = 'group';\nexport const USER_PERMISSION_TYPE: UserPermissionType = 'user';\n\nexport type PermissionType = PublicPermissionType | GroupPermissionType | UserPermissionType;\n\nexport interface ItemPermissionsOf<T> {\n    type: PermissionType;\n    permissions: T[];\n    id?: number;\n    name?: string;\n}\n\nexport type ItemPermissions = ItemPermissionsOf<Permission>;\n\nexport interface SetPermissionsRequest {\n    public?: {\n        add?: Permission[],\n        remove?: Permission[]\n    };\n    groups?: {\n        add?: NumericDictionary<Permission[]> | Dictionary<Permission[]>\n        remove?: NumericDictionary<Permission[]> | Dictionary<Permission[]>\n    };\n    users?: {\n        add?: NumericDictionary<Permission[]> | Dictionary<Permission[]>\n        remove?: NumericDictionary<Permission[]> | Dictionary<Permission[]>\n    };\n    share_content?: '0' | '1';\n}\n\n\n// ------------------------------------------------------------------\n// Contributor\n\nexport interface Contributor {\n    id: number;\n    username: string;\n    first_name: string;\n    last_name: string;\n}\n\n\n// ------------------------------------------------------------------\n// Process\n\nexport type ProcessPermissions = ViewPermission | SharePermission;\n\nexport type RawProcessPersistence = 'RAW';\nexport type CachedProcessPersistence = 'CAC';\nexport type TempProcessPersistence = 'TMP';\n\nexport const RAW_PROCESS_PERSISTENCE: RawProcessPersistence = 'RAW';\nexport const CACHED_PROCESS_PERSISTENCE: CachedProcessPersistence = 'CAC';\nexport const TEMP_PROCESS_PERSISTENCE: TempProcessPersistence = 'TMP';\n\nexport type ProcessPersistence = RawProcessPersistence | CachedProcessPersistence | TempProcessPersistence;\n\nexport interface Process {\n    id: number;\n    slug: string;\n    name: string;\n    created: string;\n    modified: string;\n    version: number;\n    type: string;\n    category: string;\n    persistence: ProcessPersistence;\n    description: string;\n    input_schema: any;\n    output_schema: any;\n    run: any;\n    contributor: Contributor;\n    current_user_permissions: ItemPermissionsOf<ProcessPermissions>[];\n}\n\n// ------------------------------------------------------------------\n// Relation\n\n// Relation entity\nexport interface RelationEntity {\n    entity: number;\n    position: string;\n}\n\nexport interface Relation {\n    id: number;\n    slug: string;\n    created: string;\n    modified: string;\n    type: string;\n    collection: number;\n    entities: RelationEntity[];\n    positions: string[];\n    label: string;\n    contributor: Contributor;\n\n}\n\n// ------------------------------------------------------------------\n// DescriptorSchema\n\n// Schema\nexport interface ChoiceMap {\n    value: string;\n    label: string;\n}\n\nexport interface FieldSchema {\n    disabled?: boolean | string;\n    required?: boolean;\n    collapsed?: boolean;\n    hidden?: boolean | string;\n    default?: any;\n    choices?: ChoiceMap[];\n    allow_custom_choice?: boolean;\n    validate_regex?: string;\n    slug?: {\n        source?: string;\n        uniqueValidator?: (slug: string) => Rx.Observable<boolean>;\n    };\n    type: string;\n    name: string;\n    label: string;\n    group?: Schema;\n}\n\nexport type Schema = FieldSchema[];\n\n\n// DescriptorSchema\nexport type DescriptorSchemaPermissions = ViewPermission | EditPermission | SharePermission;\n\nexport interface DescriptorSchemaBase {\n    id: number;\n    created: string;\n    modified: string;\n    slug: string;\n    name: string;\n    version: number;\n    schema: Schema;\n    contributor: Contributor;\n}\n\nexport interface DescriptorSchema extends DescriptorSchemaBase {\n    current_user_permissions: ItemPermissionsOf<DescriptorSchemaPermissions>[];\n}\n\n\n// ------------------------------------------------------------------\n// Scatter Plot Json\n\n// ScatterPlotJson.RootObject is a type of process output. Processes (i.e. Rose2)\n// save it to data.output.scatter_plot.\nexport namespace ScatterPlotJson {\n\n    export interface RootObject { // This is the actual type of the json output\n        points: Points;\n        meta?: Meta;\n        annotations?: Annotation[];\n    }\n\n    export interface Points {\n        x_axis: number[];\n        y_axis: number[];\n        items?: any[];\n    }\n\n    export interface Meta {\n        x_label?: string;\n        y_label?: string;\n        text?: string;\n        chr_pos?: string[];\n    }\n\n    export type Annotation = AnnotationLineGeneral | AnnotationLineVertical | AnnotationLineHorizontal;\n\n    export interface AnnotationLineGeneral {\n        type: 'line';\n        x1: number;\n        x2: number;\n        y1: number;\n        y2: number;\n    }\n    export interface AnnotationLineVertical {\n        type: 'line_vertical';\n        x: number;\n    }\n    export interface AnnotationLineHorizontal {\n        type: 'line_horizontal';\n        y: number;\n    }\n}\n\n// ------------------------------------------------------------------\n// Data\n\nexport type DataPermissions = ViewPermission | EditPermission | SharePermission | DownloadPermission;\n\nexport type UploadingDataStatus = 'UP';\nexport type ResolvingDataStatus = 'RE';\nexport type WaitingDataStatus = 'WT';\nexport type ProcessingDataStatus = 'PR';\nexport type DoneDataStatus = 'OK';\nexport type ErrorDataStatus = 'ER';\nexport type DirtyDataStatus = 'DR';\n\nexport const UPLOADING_DATA_STATUS: UploadingDataStatus = 'UP';\nexport const RESOLVING_DATA_STATUS: ResolvingDataStatus = 'RE';\nexport const WAITING_DATA_STATUS: WaitingDataStatus = 'WT';\nexport const PROCESSING_DATA_STATUS: ProcessingDataStatus = 'PR';\nexport const DONE_DATA_STATUS: DoneDataStatus = 'OK';\nexport const ERROR_DATA_STATUS: ErrorDataStatus = 'ER';\nexport const DIRTY_DATA_STATUS: DirtyDataStatus = 'DR';\n\nexport type DataStatus = UploadingDataStatus | ResolvingDataStatus | WaitingDataStatus | ProcessingDataStatus |\n    DoneDataStatus | ErrorDataStatus | DirtyDataStatus;\n\nexport interface DataBase {\n    id: number;\n    created: string;\n    modified: string;\n    started: string;\n    finished: string;\n    checksum: string;\n    status: DataStatus;\n    process_progress: number;\n    process_rc: number;\n    process_info: string[];\n    process_warning: string[];\n    process_error: string[];\n    process_type: string;\n    process_input_schema: any;\n    process_output_schema: any;\n    process_slug: string;\n    process_name: string;\n    slug: string;\n    name: string;\n    input: any;\n    output: any;\n    descriptor_schema: DescriptorSchemaBase;\n    descriptor: any;\n    contributor: Contributor;\n    process: number;\n}\n\nexport interface Data extends DataBase {\n    current_user_permissions: ItemPermissionsOf<DataPermissions>[];\n}\n\nexport function isData(object: CollectionBase | SampleBase | Data): object is Data {\n    return _.all(['checksum', 'status', 'process', 'process_name', 'process_type', 'input', 'output', 'current_user_permissions'],\n        (property) => object.hasOwnProperty(property)\n    );\n}\n\n// ------------------------------------------------------------------\n// data:differentialexpression:\n\nexport interface DataDifferentialExpression extends Data {\n    output: {\n        de_file: { file: string, size: number };\n        raw: { file: string, size: number };\n        de_json: number;\n        source: string;\n        species: string;\n    };\n}\n\n// ------------------------------------------------------------------\n// data:geneset:\n\nexport interface DataGenesetOutput {\n    geneset: { file: string, size: number };\n    geneset_json: number; // => DataGenesetStorage\n    source: string;\n    species: string;\n}\n\nexport interface DataGeneset extends Data {\n    output: DataGenesetOutput;\n}\n\nexport interface DataGenesetStorage extends Storage {\n    json: {\n        genes: string[];\n    };\n}\n\n// ------------------------------------------------------------------\n// data:geneset:venn:\n\nexport interface DataGenesetVennOutput extends DataGenesetOutput {\n    venn: number; // => DataGenesetVennStorage\n}\n\nexport interface DataGenesetVenn extends DataGeneset {\n    output: DataGenesetVennOutput;\n}\n\nexport interface DataGenesetVennStorage extends Storage {\n    json: {\n        parents: Array<{\n            id: number;\n            name: string;\n            genes: string[]; // geneset_json . genes\n        }>;\n    };\n}\n\n// ------------------------------------------------------------------\n// data:goea: Gene Ontology\n\nexport interface DataGOEnrichmentAnalysis extends Data {\n    output: {\n        terms: number; // => DataGOEnrichmentAnalysisStorage\n        source: string;\n        species: string;\n    };\n}\n\nexport type GOEnrichmentAspect = GOEnrichmentNode[];\nexport interface GOEnrichmentJson {\n    total_genes: number;\n    gene_associations: {\n        [goTermId: string]: string[]; // term_id => gene_ids\n    };\n    tree: {\n        [aspectSlug: string]: GOEnrichmentAspect, // \"BP\" | \"CC\" | \"MF\"\n    };\n}\n\nexport interface GOEnrichmentNode {\n    gene_ids: string[];\n    term_name: string;\n    term_id: string;\n    pval: number;\n    score: number;\n    matched: number; // Number of found elements in a single node.\n    total: number; // Total number of elements (including children nodes) in a single node.\n    children?: GOEnrichmentNode[];\n\n    // Added by frontend:\n    depth?: number; // Numerical representation of the level of depth. Used for offsetting the term column.\n    source?: string;\n    species?: string;\n    score_percentage?: number; // Percentage of max score within GOEnrichmentAspect.\n    gene_associations?: string[]; // Plucked from GOEnrichmentJson.gene_associations.\n    collapsed?: boolean; // Boolean representation if the selected item is hidden.\n}\n\nexport interface DataGOEnrichmentAnalysisStorage extends Storage {\n    json: GOEnrichmentJson;\n}\n\nexport interface DataGOEnrichmentAnalysisInput {\n    pval_threshold: number;\n    genes: string[];\n    source: string;\n    species: string;\n    ontology: number;\n    gaf: number;\n}\n\n// ------------------------------------------------------------------\n// data:gaf: GAF annotation\n\nexport interface DataGafAnnotation extends Data {\n    output: {\n        source: string;\n        species: string;\n        gaf: { file: string, size: number };\n        gaf_obj: { file: string, size: number };\n    };\n}\n\n// ------------------------------------------------------------------\n// data:varianttable:\n\nexport interface DataVariantTable extends Data {\n    output: {\n        variant_table: number; // => DataVariantTableStorage\n    };\n}\n\nexport type DataVariantTableJsonValueColumn = string; // Example: MSH6_exon5_F1/2\nexport type DataVariantTableJsonDelimitedColumn = string; // Example: DP4=46,41,11,16;SB=4\nexport type DataVariantTableJsonUrlsColumn = [string, string][]; // Example: [['Gene', 'http://www.ncbi.nlm.nih.gov/gene/?term=gene']]\nexport type DataVariantTableJsonColumn = DataVariantTableJsonValueColumn |\n                                         DataVariantTableJsonDelimitedColumn |\n                                         DataVariantTableJsonUrlsColumn;\nexport interface DataVariantTableRow {\n    columns: DataVariantTableJsonColumn[];\n    pos: string;\n}\n\nexport interface DataVariantTableJson { // api-typecheck:amplicon_table_output.json.gz\n    column_types: Array<'value' | 'delimited' | 'urls'>;\n    headers: string[];\n    labels: string[];\n    data: DataVariantTableRow[];\n}\n\nexport interface DataVariantTableStorage extends Storage {\n    json: DataVariantTableJson;\n}\n\n// ------------------------------------------------------------------\n// Collection\n\nexport type CollectionPermissions = ViewPermission | EditPermission | SharePermission |\n    DownloadPermission | AddPermission;\n\nexport interface CollectionBase {\n    id: number;\n    created: string;\n    modified: string;\n    slug: string;\n    name: string;\n    description: string;\n    settings: any;\n    descriptor_schema: DescriptorSchemaBase;\n    descriptor: any;\n    contributor: Contributor;\n    current_user_permissions: ItemPermissionsOf<CollectionPermissions>[];\n}\n\nexport interface Collection extends CollectionBase {\n    data: number[];\n}\n\nexport function isCollection(object: CollectionBase | SampleBase | Data): object is Collection | CollectionHydrateData {\n    // CollectionBase doesn't contain `data` property in it's interface, but\n    // Collection and CollectionHydrateData do.\n    return object.hasOwnProperty('description') &&\n        object.hasOwnProperty('settings') &&\n        object.hasOwnProperty('data') &&\n        !object.hasOwnProperty('descriptor_completed');\n}\n\nexport interface CollectionHydrateData extends CollectionBase {\n    data: DataBase[];\n}\n\nexport interface SampleBase extends CollectionBase {\n    descriptor_completed: boolean;\n}\n\nexport function isSampleBase(object: CollectionBase | SampleBase | Data): object is SampleBase {\n    return object.hasOwnProperty('description') &&\n        object.hasOwnProperty('settings') &&\n        object.hasOwnProperty('data') &&\n        object.hasOwnProperty('descriptor_completed');\n}\n\nexport interface Sample extends Collection, SampleBase {\n    descriptor_completed: true;\n}\n\nexport interface SampleHydrateData extends CollectionHydrateData, SampleBase {\n}\n\nexport interface Presample extends Collection, SampleBase {\n    descriptor_completed: false;\n}\n\nexport interface PresampleHydrateData extends CollectionHydrateData, SampleBase {\n    descriptor_completed: false;\n}\n\n\n// ------------------------------------------------------------------\n// Storage\n\nexport interface Storage {\n    id: number;\n    slug: string;\n    name: string;\n    data: number;\n    json: any;\n    contributor: Contributor;\n    created: string;\n    modified: string;\n}\n\nexport interface SampleClustering { // api-typecheck:sample_cluster_data.json.gz\n    sample_ids: _.Dictionary<{ id: number }>;\n    order: number[];\n    linkage: number[][]; // [[node1, node2, distance, number of samples]]\n    zero_sample_ids: number[]; // sample ids with no expressions\n    zero_gene_symbols: string[]; // gene symbols with no expressions\n    missing_gene_symbols: string[];\n}\n\nexport interface GeneClustering { // api-typecheck:gene_cluster_data.json.gz\n    gene_symbols: _.Dictionary<{ gene: string }>;\n    order: number[];\n    linkage: number[][]; // [[node1, node2, distance, number of genes]]\n    zero_sample_ids: number[]; // sample ids with no expressions\n    zero_gene_symbols: string[]; // gene symbols with no expressions\n    missing_gene_symbols: string[];\n}\n\nexport interface PCA { // api-typecheck:pca_plot_ncbi.json.gz\n    explained_variance_ratios: number[];\n    all_explained_variance_ratios: number[];\n    all_components: [string, number][][];\n    components: [string, number][][];\n    zero_gene_symbols: string[]; // gene ids with no expressions\n    flot: {\n        xlabel: string;\n        ylabel: string;\n        data: number[][];\n        sample_ids: string[];\n    };\n}\n\nexport interface QCStorage extends Storage {\n    json: {\n        status: 'PASS' | 'FAIL' | 'WARNING',\n        message: string,\n    };\n}\n\n\n// ------------------------------------------------------------------\n// User\n\nexport interface User {\n    id: number;\n    username: string;\n    email: string;\n    first_name: string;\n    last_name: string;\n    job_title: string;\n    company: string;\n    department: string;\n    location: string;\n    lab: string;\n    phone_number: string;\n    last_login: string;\n    date_joined: string;\n}\n\nexport interface LoginResponse {\n    key: string;\n}\n\nexport interface LogoutResponse {\n}\n\nexport interface CreateAccountInformation {\n    username: string;\n    password: string;\n    email: string;\n    first_name: string;\n    last_name: string;\n    job_title?: string;\n    company?: string;\n    department?: string;\n    location?: string;\n    lab?: string;\n    phone_number?: string;\n    newsletter?: boolean;\n    community?: string;\n}\n\nexport interface ActivateAccountResponse {\n    username: string;\n}\n\n\n// ------------------------------------------------------------------\n// File\n\nexport interface Download {\n    data: string;\n}\n"]} |
@@ -271,3 +271,2 @@ "use strict"; | ||
if (!store) { | ||
throw new error_1.GenError("Ignored missing store: " + storeMetadata.propertyName + " " + _this.globalStateId); | ||
} | ||
@@ -433,2 +432,2 @@ if (!store) | ||
//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["../src/core/components/stateful.ts"],"names":[],"mappings":"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","file":"core/components/stateful.js","sourcesContent":["import * as _ from 'lodash';\nimport * as angular from 'angular';\n\nimport {ComponentBase, component, ComponentConfiguration, Subscription} from './base';\nimport {SharedStore, SharedStoreManager} from '../shared_store/index';\nimport {StateManager} from './manager';\nimport {GenError} from '../errors/error';\n\nexport class StateItemMetadata {\n    constructor(public propertyName: string, public shared: boolean) {\n    }\n\n    public getSharedStoreNameProperty(): string {\n        return '_sharedStoreName_' + this.propertyName;\n    }\n}\n\nexport interface StateMetadata {\n    [index: string]: StateItemMetadata;\n}\n\ninterface SharedStoreSubscribeRequest {\n    (): void;\n}\n\n/**\n * A component which contains state that may be saved and reloaded later. Such\n * stateful components are automatically organized into a hierarchy, so that\n * parents also store state for all their children. Calling `saveState` on the\n * top-level component will therefore save the state of the complete application.\n *\n * Component state is defined by using property decorators as follows:\n * ```\n * export class ProcessGroups extends ViewComponent {\n *     @state() public selectedGroup: number;\n *\n *     // ...\n * }\n * ```\n *\n * It may be then referenced and watched from the controller or templates and\n * will automatically be saved when calling [[StatefulComponentBase.saveState]]\n * and reloaded when calling [[StatefulComponentBase.loadState]].\n *\n * A related decorator may be used to declare state, which is shared between\n * multiple components:\n * ```\n * export class WidgetRose2 extends WidgetBase {\n *     @sharedState() public selectedValue: SharedStore<types.Data>;\n *\n *     // ...\n * }\n * ```\n *\n * See [[SharedStoreManager]] and [[SharedStore]] for more documentation on\n * defining shared state using shared stores.\n *\n * For example, if a stateful component defines a shared state property called\n * `selectedValue` (as shown above) and you want to link it with the shared store\n * named `rose2-selected-data-item`, you can do the following in your template:\n * ```html\n * <gen-widget-rose2 store-selected-value=\"rose2-selected-data-item\"></gen-widget-rose2>\n * ```\n *\n * Note that the template attribute name is prefixed with `store` even when the\n * property is called just `selectedValue`. This is done because what you pass\n * in the template is just a name of the store, which must be resolved using the\n * shared store manager.\n *\n * Inside the components you can then dispatch and subscribe to the underlying\n * store:\n * ```\n * // Publish something by dispatching an action to the shared store.\n * this.selectedValue.dispatch({type: Actions.SET, value: 42});\n *\n * // Subscribe to updates of the shared store.\n * this.subscribeSharedState('selectedValue', (data) => {\n *     console.log(\"Shared state 'selectedValue' is now\", data);\n * });\n * ```\n */\n@component({\n    abstract: true,\n    bindings: {\n        stateId: '@stateId',\n    },\n})\nexport abstract class StatefulComponentBase extends ComponentBase {\n    /// Metadata about the state defined on the component.\n    public __stateMetadata: StateMetadata;\n    /// This component's local state identifier.\n    public stateId: string;\n    /// This component's global state identifier.\n    public globalStateId: string;\n    /// Parent stateful component.\n    private _parent: StatefulComponentBase = null;\n    /// A list of child stateful components.\n    private _children: StatefulComponentBase[] = [];\n    /// State manager.\n    private _stateManager: StateManager;\n    /// Shared store manager.\n    private _sharedStoreManager: SharedStoreManager;\n    /// Subscription requests for shared stores.\n    private _sharedStoreSubscribeRequests: SharedStoreSubscribeRequest[] = [];\n    /// Subscriptions to shared stores.\n    private _sharedStoreSubscriptions: Subscription[] = [];\n\n    // @ngInject\n    constructor($scope: angular.IScope, stateManager: StateManager) {\n        super($scope);\n\n        this._stateManager = stateManager;\n        this._sharedStoreManager = stateManager.sharedStoreManager;\n    }\n\n    public onComponentInit() {\n        super.onComponentInit();\n\n        // When state identifier is not defined, default to directive name.\n        if (_.isEmpty(this.stateId)) {\n            this.stateId = this.getConfig().directive;\n        }\n\n        // Determine our parent and register ourselves with it.\n        this._parent = this._findParentComponent();\n        if (this._parent) {\n            this._parent._registerChild(this);\n            this.globalStateId = this._parent.globalStateId + '-' + this.stateId;\n        } else {\n            this._stateManager.addTopLevelComponent(this);\n            this.globalStateId = this.stateId;\n        }\n\n        // Check if there is any pending state for us.\n        this._stateManager.loadPendingComponentState(this);\n\n        // Automatically load any configured shared state.\n        const stateMetadata = this.__stateMetadata;\n        _.forOwn(stateMetadata, (metadata) => {\n            if (metadata.shared) {\n                const sharedStoreName = this[metadata.getSharedStoreNameProperty()];\n                if (!_.isEmpty(sharedStoreName)) {\n                    const store = this._sharedStoreManager.getStore(sharedStoreName);\n                    this[metadata.propertyName] = store;\n                }\n\n                this._setupSharedStore(metadata.propertyName);\n            }\n        });\n    }\n\n    /**\n     * Sets up the shared store. This method may be overriden by subclasses when something\n     * different should be done here.\n     *\n     * @param {store} Shared state\n     */\n    protected _setupSharedStore(store: string): void {\n        // Subscribe to shared store, so that this component's scope gets updated when the\n        // value in the store is updated.\n        this.subscribeSharedState(store, _.noop);\n    }\n\n    /**\n     * Returns the state manager.\n     */\n    public get stateManager(): StateManager {\n        return this._stateManager;\n    }\n\n    /**\n     * Returns the shared store manager.\n     */\n    protected get sharedStoreManager(): SharedStoreManager {\n        return this._sharedStoreManager;\n    }\n\n    public onComponentDestroyed(): void {\n        // Save current component state, so it will be available when this component\n        // is instantiated again.\n        this._stateManager.savePendingComponentState(this);\n\n        if (this._parent) {\n            this._parent._unregisterChild(this);\n        } else {\n            this._stateManager.removeTopLevelComponent(this);\n        }\n\n        super.onComponentDestroyed();\n    }\n\n    /**\n     * This method will be called after the component's state has been loaded.\n     */\n    public onComponentStateAfterLoad(): void {\n        // Do nothing by default.\n    }\n\n    /**\n     * This method will be called before the component's state has been saved.\n     */\n    public onComponentStatePreSave(): void {\n        // Do nothing by default.\n    }\n\n    /**\n     * Discovers the parent stateful component.\n     */\n    private _findParentComponent(): StatefulComponentBase {\n        let scope = this.$scope.$parent;\n        while (scope) {\n            if (scope['ctrl'] instanceof StatefulComponentBase) {\n                return scope['ctrl'];\n            }\n\n            scope = scope.$parent;\n        }\n\n        return null;\n    }\n\n    /**\n     * Registers a new child of this stateful component.\n     *\n     * @param {StatefulComponentBase} child Child component instance\n     */\n    private _registerChild(child: StatefulComponentBase) {\n        // Ensure the child's local state id is unique.\n        if (_.any(this._children, (c) => c.stateId === child.stateId)) {\n            throw new GenError(\"Duplicate stateful component state identifier '\" + child.stateId + \"'.\");\n        }\n\n        this._children.push(child);\n    }\n\n    /**\n     * Unregisters an existing child of this stateful component.\n     *\n     * @param {StatefulComponentBase} child Child component instance\n     */\n    private _unregisterChild(child: StatefulComponentBase) {\n        this._children = _.without(this._children, child);\n    }\n\n    /**\n     * Returns the parent stateful component.\n     */\n    public parentComponent(): StatefulComponentBase {\n        return this._parent;\n    }\n\n    /**\n     * Returns a list of child stateful components.\n     */\n    public childComponents(): StatefulComponentBase[] {\n        return _.clone(this._children);\n    }\n\n    /**\n     * Finds a child component by its state identifier.\n     *\n     * @param {string} stateId Child's state identifier\n     * @return {StatefulComponentBase} Child component instance\n     */\n    public getChildComponent<T extends StatefulComponentBase>(stateId: string): T {\n        return <T> _.find(this._children, (child) => child.stateId === stateId);\n    }\n\n    /**\n     * Subscribes to shared state. This is the same as a normal subscribe, but in\n     * addition it also properly handles underlying data store changes when\n     * component state is reloaded.\n     *\n     * The value observed from the shared store MUST NOT be mutated in any way as\n     * doing so may cause undefined behavior. If you need to mutate the observed\n     * value, use [[subscribeSharedStateMutable]] instead.\n     *\n     * @param {string} name Name of shared state\n     * @param callback Callback to be invoked on subscription\n     */\n    public subscribeSharedState(name: string, callback: (value: any) => void): void {\n        const storeMetadata = this._getStateMetadata(name);\n        if (!storeMetadata || !storeMetadata.shared) {\n            throw new GenError(\"Shared state '\" + name + \"' not found.\");\n        }\n\n        const subscriber = () => {\n            const store: SharedStore<any, any> = this[storeMetadata.propertyName];\n            if (!store) {\n                // @ifndef GENJS_PRODUCTION\n                    throw new GenError(`Ignored missing store: ${storeMetadata.propertyName} ${this.globalStateId}`);\n                // @endif\n            }\n            if (!store) return;\n            this._sharedStoreSubscriptions.push(this.subscribe(callback, store.observable()));\n        };\n\n        this._sharedStoreSubscribeRequests.push(subscriber);\n        subscriber();\n    }\n\n    /**\n     * A version of [[subscribeSharedState]], which ensures that the observed shared\n     * store value is copied and can thus be safely mutated afterwards.\n     *\n     * @param {string} name Name of shared state\n     * @param callback Callback to be invoked on subscription\n     */\n    public subscribeSharedStateMutable<T>(name: string, callback: (value: T) => void): void {\n        this.subscribeSharedState(name, (value) => callback(angular.copy(value)));\n    }\n\n    /**\n     * Returns metadata for specific component state.\n     *\n     * @param {string} name Name of shared state (not property name)\n     * @return {StateItemMetadata} State metadata\n     */\n    private _getStateMetadata(name: string): StateItemMetadata {\n        return this.__stateMetadata[name];\n    }\n\n    /**\n     * Saves this component's current state and returns it.\n     */\n    public saveState(saveChildren: boolean = true): any {\n        this.onComponentStatePreSave();\n\n        let result = {};\n        let state = result[this.globalStateId] = {};\n        _.forOwn(this.__stateMetadata, (metadata, key) => {\n            let value = this[metadata.propertyName];\n\n            if (metadata.shared) {\n                // In case of shared state, save the identifier of the shared store.\n                value = (<SharedStore<any, any>> value).storeId;\n            }\n\n            state[key] = value;\n        });\n\n        // Save child state.\n        if (saveChildren) {\n            for (const child of this._children) {\n                _.extend(result, child.saveState());\n            }\n        }\n\n        return result;\n    }\n\n    /**\n     * Loads this component's current state.\n     *\n     * @param {any} globalState Global state\n     */\n    public loadState(globalState: any, loadChildren: boolean = true): void {\n        const state = globalState[this.globalStateId];\n        let sharedStateChanged = false;\n        _.forOwn(this.__stateMetadata, (metadata, key) => {\n            let value = state[key];\n            if (_.isUndefined(value)) return;\n\n            if (metadata.shared) {\n                // Get the shared store from the shared store manager.\n                const existingValue: SharedStore<any, any> = this[metadata.propertyName];\n                if (existingValue.storeId !== value) {\n                    this[metadata.propertyName] = this._sharedStoreManager.getStore<any>(value);\n                    sharedStateChanged = true;\n                }\n            } else {\n                this[metadata.propertyName] = value;\n            }\n        });\n\n        // Load child state.\n        if (loadChildren) {\n            for (const child of this._children) {\n                child.loadState(globalState);\n            }\n        }\n\n        if (sharedStateChanged) {\n            // Cancel any previous subscriptions to shared stores.\n            for (const subscription of this._sharedStoreSubscriptions) {\n                subscription.unsubscribe();\n            }\n\n            // Resubscribe, using the new stores.\n            for (const request of this._sharedStoreSubscribeRequests) {\n                request();\n            }\n        }\n\n        this.onComponentStateAfterLoad();\n\n        // Propagate state updates to the view.\n        this.$scope.$applyAsync();\n    }\n\n    public static configureComponent(config: ComponentConfiguration): ComponentConfiguration {\n        const stateMetadata = this.prototype.__stateMetadata;\n        if (!config.bindings) config.bindings = {};\n\n        _.forOwn(stateMetadata, (metadata, key) => {\n            if (metadata.shared) {\n                config.bindings[metadata.getSharedStoreNameProperty()] = '@store' + _.capitalize(key);\n            }\n        });\n        return config;\n    }\n}\n\n/**\n * Marks a property as being part of the component's state.\n *\n * @param {string} name Optional state name\n * @param {boolean} shared Does this state reference a shared store\n */\nexport function state(name?: string, shared: boolean = false) {\n    return (target: StatefulComponentBase, propertyKey: string) => {\n        if (!name) name = propertyKey;\n\n        if (name[0] === '_') {\n            throw new GenError(\"State identifiers starting with an underscore are reserved.\");\n        }\n\n        if (!target.__stateMetadata) {\n            target.__stateMetadata = {};\n        }\n\n        if (target.__stateMetadata[name]) {\n            throw new GenError(\"Duplicate state identifier '\" + name + \"' on stateful component '\" + target + \"'.\");\n        }\n        target.__stateMetadata[name] = new StateItemMetadata(propertyKey, shared);\n    };\n}\n\n/**\n * Marks a property as being part of the component's state, which references\n * a shared store.\n *\n * @param {string} name Optional state name\n */\nexport function sharedState(name?: string) {\n    return state(name, true);\n}\n"]} | ||
//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["../src/core/components/stateful.ts"],"names":[],"mappings":"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","file":"core/components/stateful.js","sourcesContent":["import * as _ from 'lodash';\nimport * as angular from 'angular';\n\nimport {ComponentBase, component, ComponentConfiguration, Subscription} from './base';\nimport {SharedStore, SharedStoreManager} from '../shared_store/index';\nimport {StateManager} from './manager';\nimport {GenError} from '../errors/error';\n\nexport class StateItemMetadata {\n    constructor(public propertyName: string, public shared: boolean) {\n    }\n\n    public getSharedStoreNameProperty(): string {\n        return '_sharedStoreName_' + this.propertyName;\n    }\n}\n\nexport interface StateMetadata {\n    [index: string]: StateItemMetadata;\n}\n\ninterface SharedStoreSubscribeRequest {\n    (): void;\n}\n\n/**\n * A component which contains state that may be saved and reloaded later. Such\n * stateful components are automatically organized into a hierarchy, so that\n * parents also store state for all their children. Calling `saveState` on the\n * top-level component will therefore save the state of the complete application.\n *\n * Component state is defined by using property decorators as follows:\n * ```\n * export class ProcessGroups extends ViewComponent {\n *     @state() public selectedGroup: number;\n *\n *     // ...\n * }\n * ```\n *\n * It may be then referenced and watched from the controller or templates and\n * will automatically be saved when calling [[StatefulComponentBase.saveState]]\n * and reloaded when calling [[StatefulComponentBase.loadState]].\n *\n * A related decorator may be used to declare state, which is shared between\n * multiple components:\n * ```\n * export class WidgetRose2 extends WidgetBase {\n *     @sharedState() public selectedValue: SharedStore<types.Data>;\n *\n *     // ...\n * }\n * ```\n *\n * See [[SharedStoreManager]] and [[SharedStore]] for more documentation on\n * defining shared state using shared stores.\n *\n * For example, if a stateful component defines a shared state property called\n * `selectedValue` (as shown above) and you want to link it with the shared store\n * named `rose2-selected-data-item`, you can do the following in your template:\n * ```html\n * <gen-widget-rose2 store-selected-value=\"rose2-selected-data-item\"></gen-widget-rose2>\n * ```\n *\n * Note that the template attribute name is prefixed with `store` even when the\n * property is called just `selectedValue`. This is done because what you pass\n * in the template is just a name of the store, which must be resolved using the\n * shared store manager.\n *\n * Inside the components you can then dispatch and subscribe to the underlying\n * store:\n * ```\n * // Publish something by dispatching an action to the shared store.\n * this.selectedValue.dispatch({type: Actions.SET, value: 42});\n *\n * // Subscribe to updates of the shared store.\n * this.subscribeSharedState('selectedValue', (data) => {\n *     console.log(\"Shared state 'selectedValue' is now\", data);\n * });\n * ```\n */\n@component({\n    abstract: true,\n    bindings: {\n        stateId: '@stateId',\n    },\n})\nexport abstract class StatefulComponentBase extends ComponentBase {\n    /// Metadata about the state defined on the component.\n    public __stateMetadata: StateMetadata;\n    /// This component's local state identifier.\n    public stateId: string;\n    /// This component's global state identifier.\n    public globalStateId: string;\n    /// Parent stateful component.\n    private _parent: StatefulComponentBase = null;\n    /// A list of child stateful components.\n    private _children: StatefulComponentBase[] = [];\n    /// State manager.\n    private _stateManager: StateManager;\n    /// Shared store manager.\n    private _sharedStoreManager: SharedStoreManager;\n    /// Subscription requests for shared stores.\n    private _sharedStoreSubscribeRequests: SharedStoreSubscribeRequest[] = [];\n    /// Subscriptions to shared stores.\n    private _sharedStoreSubscriptions: Subscription[] = [];\n\n    // @ngInject\n    constructor($scope: angular.IScope, stateManager: StateManager) {\n        super($scope);\n\n        this._stateManager = stateManager;\n        this._sharedStoreManager = stateManager.sharedStoreManager;\n    }\n\n    public onComponentInit() {\n        super.onComponentInit();\n\n        // When state identifier is not defined, default to directive name.\n        if (_.isEmpty(this.stateId)) {\n            this.stateId = this.getConfig().directive;\n        }\n\n        // Determine our parent and register ourselves with it.\n        this._parent = this._findParentComponent();\n        if (this._parent) {\n            this._parent._registerChild(this);\n            this.globalStateId = this._parent.globalStateId + '-' + this.stateId;\n        } else {\n            this._stateManager.addTopLevelComponent(this);\n            this.globalStateId = this.stateId;\n        }\n\n        // Check if there is any pending state for us.\n        this._stateManager.loadPendingComponentState(this);\n\n        // Automatically load any configured shared state.\n        const stateMetadata = this.__stateMetadata;\n        _.forOwn(stateMetadata, (metadata) => {\n            if (metadata.shared) {\n                const sharedStoreName = this[metadata.getSharedStoreNameProperty()];\n                if (!_.isEmpty(sharedStoreName)) {\n                    const store = this._sharedStoreManager.getStore(sharedStoreName);\n                    this[metadata.propertyName] = store;\n                }\n\n                this._setupSharedStore(metadata.propertyName);\n            }\n        });\n    }\n\n    /**\n     * Sets up the shared store. This method may be overriden by subclasses when something\n     * different should be done here.\n     *\n     * @param {store} Shared state\n     */\n    protected _setupSharedStore(store: string): void {\n        // Subscribe to shared store, so that this component's scope gets updated when the\n        // value in the store is updated.\n        this.subscribeSharedState(store, _.noop);\n    }\n\n    /**\n     * Returns the state manager.\n     */\n    public get stateManager(): StateManager {\n        return this._stateManager;\n    }\n\n    /**\n     * Returns the shared store manager.\n     */\n    protected get sharedStoreManager(): SharedStoreManager {\n        return this._sharedStoreManager;\n    }\n\n    public onComponentDestroyed(): void {\n        // Save current component state, so it will be available when this component\n        // is instantiated again.\n        this._stateManager.savePendingComponentState(this);\n\n        if (this._parent) {\n            this._parent._unregisterChild(this);\n        } else {\n            this._stateManager.removeTopLevelComponent(this);\n        }\n\n        super.onComponentDestroyed();\n    }\n\n    /**\n     * This method will be called after the component's state has been loaded.\n     */\n    public onComponentStateAfterLoad(): void {\n        // Do nothing by default.\n    }\n\n    /**\n     * This method will be called before the component's state has been saved.\n     */\n    public onComponentStatePreSave(): void {\n        // Do nothing by default.\n    }\n\n    /**\n     * Discovers the parent stateful component.\n     */\n    private _findParentComponent(): StatefulComponentBase {\n        let scope = this.$scope.$parent;\n        while (scope) {\n            if (scope['ctrl'] instanceof StatefulComponentBase) {\n                return scope['ctrl'];\n            }\n\n            scope = scope.$parent;\n        }\n\n        return null;\n    }\n\n    /**\n     * Registers a new child of this stateful component.\n     *\n     * @param {StatefulComponentBase} child Child component instance\n     */\n    private _registerChild(child: StatefulComponentBase) {\n        // Ensure the child's local state id is unique.\n        if (_.any(this._children, (c) => c.stateId === child.stateId)) {\n            throw new GenError(\"Duplicate stateful component state identifier '\" + child.stateId + \"'.\");\n        }\n\n        this._children.push(child);\n    }\n\n    /**\n     * Unregisters an existing child of this stateful component.\n     *\n     * @param {StatefulComponentBase} child Child component instance\n     */\n    private _unregisterChild(child: StatefulComponentBase) {\n        this._children = _.without(this._children, child);\n    }\n\n    /**\n     * Returns the parent stateful component.\n     */\n    public parentComponent(): StatefulComponentBase {\n        return this._parent;\n    }\n\n    /**\n     * Returns a list of child stateful components.\n     */\n    public childComponents(): StatefulComponentBase[] {\n        return _.clone(this._children);\n    }\n\n    /**\n     * Finds a child component by its state identifier.\n     *\n     * @param {string} stateId Child's state identifier\n     * @return {StatefulComponentBase} Child component instance\n     */\n    public getChildComponent<T extends StatefulComponentBase>(stateId: string): T {\n        return <T> _.find(this._children, (child) => child.stateId === stateId);\n    }\n\n    /**\n     * Subscribes to shared state. This is the same as a normal subscribe, but in\n     * addition it also properly handles underlying data store changes when\n     * component state is reloaded.\n     *\n     * The value observed from the shared store MUST NOT be mutated in any way as\n     * doing so may cause undefined behavior. If you need to mutate the observed\n     * value, use [[subscribeSharedStateMutable]] instead.\n     *\n     * @param {string} name Name of shared state\n     * @param callback Callback to be invoked on subscription\n     */\n    public subscribeSharedState(name: string, callback: (value: any) => void): void {\n        const storeMetadata = this._getStateMetadata(name);\n        if (!storeMetadata || !storeMetadata.shared) {\n            throw new GenError(\"Shared state '\" + name + \"' not found.\");\n        }\n\n        const subscriber = () => {\n            const store: SharedStore<any, any> = this[storeMetadata.propertyName];\n            if (!store) {\n                // @ifndef GENJS_PRODUCTION\n                    throw new GenError(`Ignored missing store: ${storeMetadata.propertyName} ${this.globalStateId}`);\n                // @endif\n            }\n            if (!store) return;\n            this._sharedStoreSubscriptions.push(this.subscribe(callback, store.observable()));\n        };\n\n        this._sharedStoreSubscribeRequests.push(subscriber);\n        subscriber();\n    }\n\n    /**\n     * A version of [[subscribeSharedState]], which ensures that the observed shared\n     * store value is copied and can thus be safely mutated afterwards.\n     *\n     * @param {string} name Name of shared state\n     * @param callback Callback to be invoked on subscription\n     */\n    public subscribeSharedStateMutable<T>(name: string, callback: (value: T) => void): void {\n        this.subscribeSharedState(name, (value) => callback(angular.copy(value)));\n    }\n\n    /**\n     * Returns metadata for specific component state.\n     *\n     * @param {string} name Name of shared state (not property name)\n     * @return {StateItemMetadata} State metadata\n     */\n    private _getStateMetadata(name: string): StateItemMetadata {\n        return this.__stateMetadata[name];\n    }\n\n    /**\n     * Saves this component's current state and returns it.\n     */\n    public saveState(saveChildren: boolean = true): any {\n        this.onComponentStatePreSave();\n\n        let result = {};\n        let state = result[this.globalStateId] = {};\n        _.forOwn(this.__stateMetadata, (metadata, key) => {\n            let value = this[metadata.propertyName];\n\n            if (metadata.shared) {\n                // In case of shared state, save the identifier of the shared store.\n                value = (<SharedStore<any, any>> value).storeId;\n            }\n\n            state[key] = value;\n        });\n\n        // Save child state.\n        if (saveChildren) {\n            for (const child of this._children) {\n                _.extend(result, child.saveState());\n            }\n        }\n\n        return result;\n    }\n\n    /**\n     * Loads this component's current state.\n     *\n     * @param {any} globalState Global state\n     */\n    public loadState(globalState: any, loadChildren: boolean = true): void {\n        const state = globalState[this.globalStateId];\n        let sharedStateChanged = false;\n        _.forOwn(this.__stateMetadata, (metadata, key) => {\n            let value = state[key];\n            if (_.isUndefined(value)) return;\n\n            if (metadata.shared) {\n                // Get the shared store from the shared store manager.\n                const existingValue: SharedStore<any, any> = this[metadata.propertyName];\n                if (existingValue.storeId !== value) {\n                    this[metadata.propertyName] = this._sharedStoreManager.getStore<any>(value);\n                    sharedStateChanged = true;\n                }\n            } else {\n                this[metadata.propertyName] = value;\n            }\n        });\n\n        // Load child state.\n        if (loadChildren) {\n            for (const child of this._children) {\n                child.loadState(globalState);\n            }\n        }\n\n        if (sharedStateChanged) {\n            // Cancel any previous subscriptions to shared stores.\n            for (const subscription of this._sharedStoreSubscriptions) {\n                subscription.unsubscribe();\n            }\n\n            // Resubscribe, using the new stores.\n            for (const request of this._sharedStoreSubscribeRequests) {\n                request();\n            }\n        }\n\n        this.onComponentStateAfterLoad();\n\n        // Propagate state updates to the view.\n        this.$scope.$applyAsync();\n    }\n\n    public static configureComponent(config: ComponentConfiguration): ComponentConfiguration {\n        const stateMetadata = this.prototype.__stateMetadata;\n        if (!config.bindings) config.bindings = {};\n\n        _.forOwn(stateMetadata, (metadata, key) => {\n            if (metadata.shared) {\n                config.bindings[metadata.getSharedStoreNameProperty()] = '@store' + _.capitalize(key);\n            }\n        });\n        return config;\n    }\n}\n\n/**\n * Marks a property as being part of the component's state.\n *\n * @param {string} name Optional state name\n * @param {boolean} shared Does this state reference a shared store\n */\nexport function state(name?: string, shared: boolean = false) {\n    return (target: StatefulComponentBase, propertyKey: string) => {\n        if (!name) name = propertyKey;\n\n        if (name[0] === '_') {\n            throw new GenError(\"State identifiers starting with an underscore are reserved.\");\n        }\n\n        if (!target.__stateMetadata) {\n            target.__stateMetadata = {};\n        }\n\n        if (target.__stateMetadata[name]) {\n            throw new GenError(\"Duplicate state identifier '\" + name + \"' on stateful component '\" + target + \"'.\");\n        }\n        target.__stateMetadata[name] = new StateItemMetadata(propertyKey, shared);\n    };\n}\n\n/**\n * Marks a property as being part of the component's state, which references\n * a shared store.\n *\n * @param {string} name Optional state name\n */\nexport function sharedState(name?: string) {\n    return state(name, true);\n}\n"]} |
"use strict"; | ||
Object.defineProperty(exports, "__esModule", { value: true }); | ||
var _ = require("lodash"); | ||
/** | ||
@@ -13,6 +12,2 @@ * Makes an object deeply immutable by using Object.freeze. The passed object | ||
function makeImmutable(object) { | ||
if (_.isObject(object)) { | ||
_.each(object, function (property) { return makeImmutable(property); }); | ||
return Object.freeze(object); | ||
} | ||
return object; | ||
@@ -22,2 +17,2 @@ } | ||
//# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9jb3JlL3V0aWxzL2ltbXV0YWJsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOztBQUFBLDBCQUE0QjtBQUU1Qjs7Ozs7OztHQU9HO0FBQ0gsdUJBQWlDLE1BQVM7SUFDdEMsRUFBRSxDQUFDLENBQUMsQ0FBQyxDQUFDLFFBQVEsQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFDLENBQUM7UUFDckIsQ0FBQyxDQUFDLElBQUksQ0FBQyxNQUFNLEVBQUUsVUFBQyxRQUFRLElBQUssT0FBQSxhQUFhLENBQUMsUUFBUSxDQUFDLEVBQXZCLENBQXVCLENBQUMsQ0FBQztRQUN0RCxNQUFNLENBQUMsTUFBTSxDQUFDLE1BQU0sQ0FBQyxNQUFNLENBQUMsQ0FBQztJQUNqQyxDQUFDO0lBRUQsTUFBTSxDQUFDLE1BQU0sQ0FBQztBQUNsQixDQUFDO0FBUEQsc0NBT0MiLCJmaWxlIjoiY29yZS91dGlscy9pbW11dGFibGUuanMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgKiBhcyBfIGZyb20gJ2xvZGFzaCc7XG5cbi8qKlxuICogTWFrZXMgYW4gb2JqZWN0IGRlZXBseSBpbW11dGFibGUgYnkgdXNpbmcgT2JqZWN0LmZyZWV6ZS4gVGhlIHBhc3NlZCBvYmplY3RcbiAqIHdpbGwgYmUgY2hhbmdlZCBzbyB0aGF0IGl0IHdpbGwgbm93IGJlIGltbXV0YWJsZSBhbmQgdGhlIHNhbWUgb2JqZWN0IHdpbGxcbiAqIGJlIHJldHVybmVkLlxuICpcbiAqIEBwYXJhbSB7VH0gb2JqZWN0IFRoZSBvYmplY3QgdG8gbWFrZSBpbW11dGFibGVcbiAqIEByZXR1cm4ge1R9IFRoZSBzYW1lIG9iamVjdCB0aGF0IHdhcyBwYXNzZWQgYXMgYW4gYXJndW1lbnRcbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIG1ha2VJbW11dGFibGU8VD4ob2JqZWN0OiBUKTogVCB7XG4gICAgLy8gQGlmbmRlZiBHRU5KU19QUk9EVUNUSU9OXG4gICAgaWYgKF8uaXNPYmplY3Qob2JqZWN0KSkge1xuICAgICAgICBfLmVhY2gob2JqZWN0LCAocHJvcGVydHkpID0+IG1ha2VJbW11dGFibGUocHJvcGVydHkpKTtcbiAgICAgICAgcmV0dXJuIE9iamVjdC5mcmVlemUob2JqZWN0KTtcbiAgICB9XG4gICAgLy8gQGVuZGlmXG5cbiAgICByZXR1cm4gb2JqZWN0O1xufVxuIl19 | ||
//# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9jb3JlL3V0aWxzL2ltbXV0YWJsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOztBQUVBOzs7Ozs7O0dBT0c7QUFDSCx1QkFBaUMsTUFBUztJQUV0QyxNQUFNLENBQUMsTUFBTSxDQUFDO0FBQ2xCLENBQUM7QUFIRCxzQ0FHQyIsImZpbGUiOiJjb3JlL3V0aWxzL2ltbXV0YWJsZS5qcyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCAqIGFzIF8gZnJvbSAnbG9kYXNoJztcblxuLyoqXG4gKiBNYWtlcyBhbiBvYmplY3QgZGVlcGx5IGltbXV0YWJsZSBieSB1c2luZyBPYmplY3QuZnJlZXplLiBUaGUgcGFzc2VkIG9iamVjdFxuICogd2lsbCBiZSBjaGFuZ2VkIHNvIHRoYXQgaXQgd2lsbCBub3cgYmUgaW1tdXRhYmxlIGFuZCB0aGUgc2FtZSBvYmplY3Qgd2lsbFxuICogYmUgcmV0dXJuZWQuXG4gKlxuICogQHBhcmFtIHtUfSBvYmplY3QgVGhlIG9iamVjdCB0byBtYWtlIGltbXV0YWJsZVxuICogQHJldHVybiB7VH0gVGhlIHNhbWUgb2JqZWN0IHRoYXQgd2FzIHBhc3NlZCBhcyBhbiBhcmd1bWVudFxuICovXG5leHBvcnQgZnVuY3Rpb24gbWFrZUltbXV0YWJsZTxUPihvYmplY3Q6IFQpOiBUIHtcbiAgICAvLyBAaWZuZGVmIEdFTkpTX1BST0RVQ1RJT05cbiAgICBpZiAoXy5pc09iamVjdChvYmplY3QpKSB7XG4gICAgICAgIF8uZWFjaChvYmplY3QsIChwcm9wZXJ0eSkgPT4gbWFrZUltbXV0YWJsZShwcm9wZXJ0eSkpO1xuICAgICAgICByZXR1cm4gT2JqZWN0LmZyZWV6ZShvYmplY3QpO1xuICAgIH1cbiAgICAvLyBAZW5kaWZcblxuICAgIHJldHVybiBvYmplY3Q7XG59XG4iXX0= |
@@ -147,5 +147,2 @@ "use strict"; | ||
mockApi = _api_; | ||
if (_.contains(tests.toString(), 'debugger') || _.contains(tests.toString(), ' fit(')) { | ||
provideRealDOM(); | ||
} | ||
})); | ||
@@ -182,2 +179,2 @@ afterEach(function () { | ||
//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["../src/tests/component.ts"],"names":[],"mappings":"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","file":"tests/component.js","sourcesContent":["import * as _ from 'lodash';\nimport * as angular from 'angular';\nimport 'angular-mocks';\n\nimport {ResolweApi} from '../api/index';\nimport {MockBase, MockApi} from '../api/mock';\nimport {ngEqualMatcher} from './matchers';\nimport {SharedStoreFactory, SharedStoreProvider} from '../core/shared_store/index';\nimport {GenError} from '../core/errors/error';\nimport {compose} from '../core/utils/lang';\nimport {MockApiService} from './mock';\nimport './matchers';\n\n// Service modules that should be loaded.\nimport '../core/shared_store/index';\nimport '../core/components/manager';\n\nexport interface ComponentDescriptor<T> {\n    element: angular.IAugmentedJQuery;\n    ctrl: T;\n}\n\nexport interface SharedStoreDescriptor {\n    storeId: string;\n    initialState?: any;\n    factory?: SharedStoreFactory<any, any>;\n}\n\n/**\n * Helper for creating simple shared stores in tests. Also see\n * [[SharedStoreProvider.create]].\n *\n * @param storeId Identifier of the shared store (must be globally unique)\n * @param initialState Optional initial state of the shared store\n */\nexport function createSharedStore(storeId: string, initialState: any = null): SharedStoreDescriptor {\n    return {\n        storeId,\n        initialState,\n    };\n}\n\n/**\n * Helper for using shared stores in tests.\n *\n * @param storeId Identifier of the shared store (must be globally unique)\n * @param factory Shared store class\n */\nexport function useSharedStore(storeId: string, factory: SharedStoreFactory<any, any>): SharedStoreDescriptor {\n    return {\n        storeId,\n        factory,\n    };\n}\n\n/**\n * Helper function when unit testing components which compiles a component.\n *\n * @param $compile Compile service\n * @param $scope Scope service\n * @param template template in the form of a directive, e.g. `'<gen-some-component><gen-some-component>'`\n * @returns {ComponentDescriptor} Element and its controller\n */\nexport function getComponent<T>($compile: angular.ICompileService, $scope: angular.IScope, template: string): ComponentDescriptor<T> {\n\n    // TODO: instead of having getComponent<T>, we could have getComponent<T extends ComponentBase> and then you would do\n    // T.asView thus reducing the need for template argument, but looks like typescript does not support that (yet)\n    // https://github.com/Microsoft/TypeScript/issues/5677\n\n    const element = $compile(template)($scope);\n    $scope.$digest();\n\n    let ctrl: T;\n    try {\n        ctrl = $scope['$$childTail'].ctrl;\n    } catch (e) {\n        throw new GenError(\"Unable to fetch component controller. Did you load your module in tests?\");\n    }\n\n    return {\n        element: element,\n        ctrl: ctrl,\n    };\n}\n\n/**\n * Interface exposed to test case functions, which are created using [[describeComponent]].\n */\nexport interface ComponentTester {\n    /// Angular module, which may be used to register test components in.\n    module: angular.IModule;\n\n    /**\n     * See [[getComponent]].\n     */\n    createComponent<T>(template: string): ComponentDescriptor<T>;\n\n    /**\n     * Runs an Angular digest cycle.\n     */\n    digest(): void;\n\n    /**\n     * Returns the mock version of the API, which may be used to simulate the backend\n     * when testing components. The mock API is automatically injected into components\n     * and replaces the usual API.\n     */\n    api(): ResolweApi & MockBase & MockApiService;\n\n    /**\n     * Returns the scope.\n     */\n    scope(): angular.IScope;\n\n    /**\n     * Ensures that the tested components are inserted into an actual DOM, so things\n     * like height calculations work as expected. This function must be called before\n     * any [[createComponent]] calls.\n     */\n    provideRealDOM(): void;\n}\n\nexport interface MockApiFactory {\n    new (...args: any[]): ResolweApi & MockBase;\n}\n\n/**\n * A helper function to ease testing of components. It will take care of mocking the\n * usual modules needed for testing components and preparing a module that you can use\n * to register test components.\n *\n * The test case is passed an instance of [[ComponentTester]], which contains some\n * useful properties and methods for testing components.\n *\n * The following modules are automatically loaded:\n * * `resolwe.services.shared_store`\n *\n * If you need to load any additional modules, specify them in the `modules`\n * argument.\n *\n * @param description Test case description\n * @param modules List of modules to load for this test\n * @param tests Test case body\n * @param apiClass Optional mock API class that should be used\n * @param baseModules Optional list of modules to load before everything for this test\n */\nexport function describeComponent(description: string,\n                                  modules: any[],\n                                  tests: (tester: ComponentTester) => void,\n                                  apiClass: MockApiFactory = MockApi,\n                                  baseModules: string[] = []): void {\n    describe(description, () => {\n        let $compile: angular.ICompileService;\n        let $scope: angular.IScope;\n        let mockApi: ResolweApi & MockBase & MockApiService;\n\n        const moduleName = 'resolwe.tests.' + description.replace(/ /g, '.');\n        const module: angular.IModule = angular.module(moduleName, []);\n\n        // Load base modules.\n        beforeEach(angular.mock.module('resolwe.services.shared_store'));\n        beforeEach(angular.mock.module('resolwe.services.state_manager'));\n        baseModules.forEach((baseModule) => beforeEach(angular.mock.module(baseModule)));\n\n        beforeEach(angular.mock.module(($provide: angular.auto.IProvideService) => {\n            // Explicitly set root element because tests do not go through usual\n            // Angular bootstrapping.\n            $provide.value('$rootElement', angular.element(document.body));\n\n            // Replace usual API service with mock API.\n            $provide.service('api', compose([apiClass, MockApiService]));\n        }));\n        beforeEach(angular.mock.module(moduleName));\n\n        // Register any shared stores.\n        const [sharedStores, additionalModules] = _.partition(modules, (m) => !!m.storeId);\n\n        module.config((sharedStoreManagerProvider: SharedStoreProvider) => {\n            _.each(sharedStores, (descriptor: SharedStoreDescriptor) => {\n                if (descriptor.factory) {\n                    sharedStoreManagerProvider.register(descriptor.storeId, descriptor.factory);\n                } else {\n                    sharedStoreManagerProvider.create(descriptor.storeId, descriptor.initialState);\n                }\n            });\n        });\n\n        _.each(additionalModules, (additionalModule) => {\n            beforeEach(angular.mock.module(additionalModule));\n        });\n\n        // A container in DOM where we can temporarily append component elements.\n        let containerElement: angular.IAugmentedJQuery = null;\n\n        function provideRealDOM(): void {\n            removeRealDOM();\n            const body = angular.element(document.body);\n            containerElement = angular.element('<div id=\"test-container-element\"></div>');\n            body.append(containerElement);\n        }\n\n        function removeRealDOM(): void {\n            if (containerElement) {\n                containerElement.remove();\n                containerElement = null;\n            }\n        }\n\n        beforeEach(() => {\n            jasmine.addMatchers(ngEqualMatcher);\n        });\n\n        beforeEach(angular.mock.inject((_$compile_, _$rootScope_, _api_) => {\n            $compile = _$compile_;\n            $scope = _$rootScope_.$new();\n            mockApi = _api_;\n\n            // @ifndef GENJS_PRODUCTION\n                if (_.contains(tests.toString(), 'debugger') || _.contains(tests.toString(), ' fit(')) {\n                    provideRealDOM();\n                }\n            // @endif\n        }));\n\n        afterEach(() => {\n            $scope.$destroy();\n            removeRealDOM();\n        });\n\n        tests({\n            module: module,\n\n            createComponent: function<T>(template: string): ComponentDescriptor<T> {\n                const component = getComponent<T>($compile, $scope, template);\n\n                if (containerElement) {\n                    // Append component element to actual DOM. Otherwise, computations like height will not work.\n                    containerElement.append(component.element);\n                    $scope.$digest();\n                }\n\n                return component;\n            },\n\n            digest: function(): void {\n                $scope.$digest();\n            },\n\n            api: function(): ResolweApi & MockBase & MockApiService {\n                return mockApi;\n            },\n\n            scope: function(): angular.IScope {\n                return $scope;\n            },\n\n            provideRealDOM: provideRealDOM,\n        });\n    });\n}\n"]} | ||
//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["../src/tests/component.ts"],"names":[],"mappings":"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","file":"tests/component.js","sourcesContent":["import * as _ from 'lodash';\nimport * as angular from 'angular';\nimport 'angular-mocks';\n\nimport {ResolweApi} from '../api/index';\nimport {MockBase, MockApi} from '../api/mock';\nimport {ngEqualMatcher} from './matchers';\nimport {SharedStoreFactory, SharedStoreProvider} from '../core/shared_store/index';\nimport {GenError} from '../core/errors/error';\nimport {compose} from '../core/utils/lang';\nimport {MockApiService} from './mock';\nimport './matchers';\n\n// Service modules that should be loaded.\nimport '../core/shared_store/index';\nimport '../core/components/manager';\n\nexport interface ComponentDescriptor<T> {\n    element: angular.IAugmentedJQuery;\n    ctrl: T;\n}\n\nexport interface SharedStoreDescriptor {\n    storeId: string;\n    initialState?: any;\n    factory?: SharedStoreFactory<any, any>;\n}\n\n/**\n * Helper for creating simple shared stores in tests. Also see\n * [[SharedStoreProvider.create]].\n *\n * @param storeId Identifier of the shared store (must be globally unique)\n * @param initialState Optional initial state of the shared store\n */\nexport function createSharedStore(storeId: string, initialState: any = null): SharedStoreDescriptor {\n    return {\n        storeId,\n        initialState,\n    };\n}\n\n/**\n * Helper for using shared stores in tests.\n *\n * @param storeId Identifier of the shared store (must be globally unique)\n * @param factory Shared store class\n */\nexport function useSharedStore(storeId: string, factory: SharedStoreFactory<any, any>): SharedStoreDescriptor {\n    return {\n        storeId,\n        factory,\n    };\n}\n\n/**\n * Helper function when unit testing components which compiles a component.\n *\n * @param $compile Compile service\n * @param $scope Scope service\n * @param template template in the form of a directive, e.g. `'<gen-some-component><gen-some-component>'`\n * @returns {ComponentDescriptor} Element and its controller\n */\nexport function getComponent<T>($compile: angular.ICompileService, $scope: angular.IScope, template: string): ComponentDescriptor<T> {\n\n    // TODO: instead of having getComponent<T>, we could have getComponent<T extends ComponentBase> and then you would do\n    // T.asView thus reducing the need for template argument, but looks like typescript does not support that (yet)\n    // https://github.com/Microsoft/TypeScript/issues/5677\n\n    const element = $compile(template)($scope);\n    $scope.$digest();\n\n    let ctrl: T;\n    try {\n        ctrl = $scope['$$childTail'].ctrl;\n    } catch (e) {\n        throw new GenError(\"Unable to fetch component controller. Did you load your module in tests?\");\n    }\n\n    return {\n        element: element,\n        ctrl: ctrl,\n    };\n}\n\n/**\n * Interface exposed to test case functions, which are created using [[describeComponent]].\n */\nexport interface ComponentTester {\n    /// Angular module, which may be used to register test components in.\n    module: angular.IModule;\n\n    /**\n     * See [[getComponent]].\n     */\n    createComponent<T>(template: string): ComponentDescriptor<T>;\n\n    /**\n     * Runs an Angular digest cycle.\n     */\n    digest(): void;\n\n    /**\n     * Returns the mock version of the API, which may be used to simulate the backend\n     * when testing components. The mock API is automatically injected into components\n     * and replaces the usual API.\n     */\n    api(): ResolweApi & MockBase & MockApiService;\n\n    /**\n     * Returns the scope.\n     */\n    scope(): angular.IScope;\n\n    /**\n     * Ensures that the tested components are inserted into an actual DOM, so things\n     * like height calculations work as expected. This function must be called before\n     * any [[createComponent]] calls.\n     */\n    provideRealDOM(): void;\n}\n\nexport interface MockApiFactory {\n    new (...args: any[]): ResolweApi & MockBase;\n}\n\n/**\n * A helper function to ease testing of components. It will take care of mocking the\n * usual modules needed for testing components and preparing a module that you can use\n * to register test components.\n *\n * The test case is passed an instance of [[ComponentTester]], which contains some\n * useful properties and methods for testing components.\n *\n * The following modules are automatically loaded:\n * * `resolwe.services.shared_store`\n *\n * If you need to load any additional modules, specify them in the `modules`\n * argument.\n *\n * @param description Test case description\n * @param modules List of modules to load for this test\n * @param tests Test case body\n * @param apiClass Optional mock API class that should be used\n * @param baseModules Optional list of modules to load before everything for this test\n */\nexport function describeComponent(description: string,\n                                  modules: any[],\n                                  tests: (tester: ComponentTester) => void,\n                                  apiClass: MockApiFactory = MockApi,\n                                  baseModules: string[] = []): void {\n    describe(description, () => {\n        let $compile: angular.ICompileService;\n        let $scope: angular.IScope;\n        let mockApi: ResolweApi & MockBase & MockApiService;\n\n        const moduleName = 'resolwe.tests.' + description.replace(/ /g, '.');\n        const module: angular.IModule = angular.module(moduleName, []);\n\n        // Load base modules.\n        beforeEach(angular.mock.module('resolwe.services.shared_store'));\n        beforeEach(angular.mock.module('resolwe.services.state_manager'));\n        baseModules.forEach((baseModule) => beforeEach(angular.mock.module(baseModule)));\n\n        beforeEach(angular.mock.module(($provide: angular.auto.IProvideService) => {\n            // Explicitly set root element because tests do not go through usual\n            // Angular bootstrapping.\n            $provide.value('$rootElement', angular.element(document.body));\n\n            // Replace usual API service with mock API.\n            $provide.service('api', compose([apiClass, MockApiService]));\n        }));\n        beforeEach(angular.mock.module(moduleName));\n\n        // Register any shared stores.\n        const [sharedStores, additionalModules] = _.partition(modules, (m) => !!m.storeId);\n\n        module.config((sharedStoreManagerProvider: SharedStoreProvider) => {\n            _.each(sharedStores, (descriptor: SharedStoreDescriptor) => {\n                if (descriptor.factory) {\n                    sharedStoreManagerProvider.register(descriptor.storeId, descriptor.factory);\n                } else {\n                    sharedStoreManagerProvider.create(descriptor.storeId, descriptor.initialState);\n                }\n            });\n        });\n\n        _.each(additionalModules, (additionalModule) => {\n            beforeEach(angular.mock.module(additionalModule));\n        });\n\n        // A container in DOM where we can temporarily append component elements.\n        let containerElement: angular.IAugmentedJQuery = null;\n\n        function provideRealDOM(): void {\n            removeRealDOM();\n            const body = angular.element(document.body);\n            containerElement = angular.element('<div id=\"test-container-element\"></div>');\n            body.append(containerElement);\n        }\n\n        function removeRealDOM(): void {\n            if (containerElement) {\n                containerElement.remove();\n                containerElement = null;\n            }\n        }\n\n        beforeEach(() => {\n            jasmine.addMatchers(ngEqualMatcher);\n        });\n\n        beforeEach(angular.mock.inject((_$compile_, _$rootScope_, _api_) => {\n            $compile = _$compile_;\n            $scope = _$rootScope_.$new();\n            mockApi = _api_;\n\n            // @ifndef GENJS_PRODUCTION\n                if (_.contains(tests.toString(), 'debugger') || _.contains(tests.toString(), ' fit(')) {\n                    provideRealDOM();\n                }\n            // @endif\n        }));\n\n        afterEach(() => {\n            $scope.$destroy();\n            removeRealDOM();\n        });\n\n        tests({\n            module: module,\n\n            createComponent: function<T>(template: string): ComponentDescriptor<T> {\n                const component = getComponent<T>($compile, $scope, template);\n\n                if (containerElement) {\n                    // Append component element to actual DOM. Otherwise, computations like height will not work.\n                    containerElement.append(component.element);\n                    $scope.$digest();\n                }\n\n                return component;\n            },\n\n            digest: function(): void {\n                $scope.$digest();\n            },\n\n            api: function(): ResolweApi & MockBase & MockApiService {\n                return mockApi;\n            },\n\n            scope: function(): angular.IScope {\n                return $scope;\n            },\n\n            provideRealDOM: provideRealDOM,\n        });\n    });\n}\n"]} |
{ | ||
"name": "@genialis/resolwe", | ||
"author": "Genialis Inc.", | ||
"version": "3.1.1", | ||
"version": "3.1.2", | ||
"description": "Resolwe frontend libraries", | ||
"license" : "Apache-2.0", | ||
"license": "Apache-2.0", | ||
"repository": { | ||
@@ -8,0 +8,0 @@ "type": "git", |
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is too big to display
Sorry, the diff of this file is not supported yet
876933
97
10993