Database Module
frametrail/_shared/modules/Database/module.js:5
I am the Database. I store all data coming from the server. The data model objects (like HypervideoModel) get their data from me. When they are done with manipulating the data, I can store the data back to the server.
Note: All data objects inside me must be passed by reference, so that data can be manipulated in place, and insertions and deletions should alter immediatly the database. In this way, data is kept consistent across the app (see Annotation/FrameTrail.newObject:method).
Item Index
Methods
Methods
getIdOfHypervideo
-
data
I search the hypervideo database for a given data object and return its id.
Parameters:
-
data
Object
Returns:
String or null
getIdOfResource
-
resourceData
I search the resource database for a given data object and return its id.
Parameters:
-
resourceData
Object
Returns:
String or null
loadAnnotationData
-
success
-
fail
I load the annotation data (../_data/projects/ RouteNavigation/projectID /hypervideos/ RouteNavigation/hypervideoID /hypervideo.json) from the server and save the data in my attribute Database/annotations, and the respective annotationfileIDs in my attribute Database/annotationfileIDs,
I call my success or fail callback respectively.
loadData
-
success
-
fail
I initialise the load process of the database
First I look for the RouteNavigation/projectID and RouteNavigation/hypervideoID.
Then I call the nested load functions to fetch all data from the server. I call my success or fail callback respectively.
loadHypervideoData
-
success
-
fail
I load the hypervideo index data (../_data/projects/ RouteNavigation/projectID /hypervideos/_index.json) from the server and save the data in my attribute Database/hypervideos. I call my success or fail callback respectively.
loadLinksData
-
success
-
fail
I load the video link data (../_data/projects/ RouteNavigation/projectID /hypervideos/ RouteNavigation/hypervideoID /hypervideo.json) from the server and save the data in my attribute Database/links. I call my success or fail callback respectively.
loadOverlayData
-
success
-
fail
I load the overlay data (../_data/projects/ RouteNavigation/projectID /hypervideos/ RouteNavigation/hypervideoID /hypervideo.json) from the server and save the data in my attribute Database/overlays. I call my success or fail callback respectively.
loadProjectData
-
success
-
fail
I load the project index data (../_data/projects/_index.json) from the server and save the data for my projectID (from RouteNavigation/projectID) in my attribute Database/project. I call my success or fail callback respectively.
loadResourceData
-
success
-
fail
I load the resource index data (../_data/projects/ RouteNavigation/projectID /resources/_index.json) from the server and save the data in my attribute Database/resources. I call my success or fail callback respectively.
loadSequenceData
-
success
-
fail
I load the hypervideo sequence data (../_data/projects/ RouteNavigation/projectID /hypervideos/ RouteNavigation/hypervideoID /hypervideo.json) from the server and save the data in my attribute Database/hypervideos. I call my success or fail callback respectively.
loadSubtitleData
-
success
-
fail
I load the subtitles data (../_data/projects/ RouteNavigation/projectID /hypervideos/ RouteNavigation/hypervideoID /subtitles/...) from the server and save the data in my attribute Database/subtitles:attribute
I call my success or fail callback respectively.
loadUserData
-
success
-
fail
I load the user.json of the current project from the server and save the data in my attribute Database/users. I call my success or fail callback respectively.
saveAnnotations
-
callback
I save the annotation data back to the server.
I choose by myself the appropriate server method ($_POST["action"]: "save" or "saveAs") wether the user's annotation file does already exist, or has to be created.
My success callback gets one argument, which is either
{ success: true }
or
{ failed: 'annotations', error: ... }
Parameters:
-
callback
Function
saveLinks
-
callback
I save the video link data back to the server.
My success callback gets one argument, which is either
{ success: true }
or
{ failed: 'links', error: ... }
Parameters:
-
callback
Object
saveOverlays
-
callback
I save the overlay data back to the server.
My success callback gets one argument, which is either
{ success: true }
or
{ failed: 'overlays', error: ... }
Parameters:
-
callback
Function
Attributes
annotationfileIDs
I store the file IDs of the user's annotation sets.
The server manages file names automatically without influence of the client. That is why the client has to remeber the file ID of the several sets of annotations, which belong to a single user.
{
"userID": "fileID"
}
annotations
I store the annotation data (from all json files from the server's ../_data/projects/
I am a map of keys (userIDs) to an array of all annotations from that user.
{
"userID": [ annotationData, annotationData, ... ]
}
annotations
I store the subtitle data (from all .vtt files from the server's ../_data/projects/
hypervideos
I store the hypervideo index data (from the server's ../_data/projects/
overlays
I store the overlays data (from the server's ../_data/projects/
resources
I store the resource index data (from the server's ../_data/projects/