summaryrefslogtreecommitdiff
path: root/javascript/videojs/docs/legacy-docs/api/assets/create-doc-files.js
blob: 8154a888ae567dc7a701a0a1491867800c6049db (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
/**
 * get a subset of objects in array of objects
 * based on some property value
 *
 * @param {array} targetArray - array to search
 * @param {string} objProperty - object property to search
 * @param {string|number} value - value of the property to search for
 * @return {array} array of objects with matching property value
 */
function getSubArray(targetArray, objProperty, value) {
    var i, totalItems = targetArray.length, idxArr = [];
    for (i = 0; i < totalItems; i++) {
        if (targetArray[i][objProperty] === value) {
            idxArr.push(targetArray[i]);
        }
    }
    return idxArr;
}

/**
 * create the HTML files for the classes
 * @param {array} filenameArray - array of the filenames
 */
function createFiles(filenameArray) {
    var i,
        iMax = filenameArray.length,
        filename,
        contentStr = '<!DOCTYPE html> <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> <title></title> <script src="//use.edgefonts.net/source-code-pro.js"></script> <link href="https://fonts.googleapis.com/css?family=Open+Sans:400italic,700italic,400,700" rel="stylesheet" type="text/css"> <!-- there are many other style for highlighted code here: https://cdnjs.com/libraries/highlight.js --> <link rel="stylesheet" type="text/css" href="https://cdnjs.cloudflare.com/ajax/libs/highlight.js/8.6/styles/atelier-forest.light.min.css"> <link rel="stylesheet" type="text/css" href="css/api-docs.css"> <script type="text/javascript" src="//cdnjs.cloudflare.com/ajax/libs/modernizr/2.8.3/modernizr.min.js"></script> </head> <body> <script src="//cdnjs.cloudflare.com/ajax/libs/highlight.js/8.6/highlight.min.js"></script> <script src="js/doc-data.js"></script> <script src="js/api-docs.js"></script> </body> </html>';
    for (i = 0; i < iMax; i++) {
        filename = filenameArray[i];
        // create file with name=filename and contents=contentStr
    }
}

function createFilenameArray(classData) {
    var filenameArray = [],
        i,
        iMax = classData.length,
        item,
        str;
    // extract the filenames from the class items
    for (i = 0; i < iMax; i++) {
        item = classData[i];
        str = item.meta.filename;
        str = str.substr(str.lastIndexOf('/') + 1);
        str = str.replace('.js', '.html');
        filenameArray.push(str);
    }
    // videojs is special case
    filenameArray.push('video.html');
    filenameArray = filenameArray.sort();
    console.log('filenameArray', filenameArray);
    // now create the files
    createFiles(filenameArray);
}
/**
 * extracts class items from doc data
 * @param  {array} docData JSON output from JSDoc
 */
function getClassData(docData) {
    var classData = [];
    // extract the class items from the doc data
    classData = getSubArray(docData, 'kind', 'class');
    // now create the array of filenames
    createFilenameArray(classData);
}

getClassData(docData);