aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/lib/scripts/localdraft.js
blob: 018b37b5e07540b52baf51c1231c3de7b4285e86 (plain) (blame)
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
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
var localdraft = {
    $form: null,
    timer: null,

    init: function () {
        if (!localdraft.supports_html5_storage()) {
            return;
        }

        localdraft.$form = jQuery('#dw__editform');
        if (localdraft.$form.length) {
            // register draft saving
            jQuery('#wiki__text').keyup(function () {
                // save after 500ms iactivity
                if (localdraft.timer) window.clearTimeout(localdraft.timer);
                localdraft.timer = window.setTimeout(localdraft.saveDraft, 500);
            });
        } else {
            localdraft.clearSavedDraft();
            // if a draft still exists it needs to be sent to the server
            localdraft.saveRemoteDraft();
        }
    },

    /**
     * Check if localstorage is available
     *
     * @returns {boolean}
     */
    supports_html5_storage: function () {
        try {
            return 'localStorage' in window && window['localStorage'] !== null;
        } catch (e) {
            return false;
        }
    },

    /**
     * deletes a draft that has been successfully saved already
     *
     * It compares the last save date with the date of the revision the draft was editing.
     * So this behaves similar to the remote drafts in that a draft will be deleted when
     * someone else edited the page meanwhile
     */
    clearSavedDraft: function () {
        var draft_date = window.localStorage.getItem('draft_date-' + JSINFO.id);
        if (draft_date && draft_date < JSINFO['lastmod']) {
            localdraft.removeDraft();
        }
    },

    /**
     * remove local draft of the local page
     */
    removeDraft: function () {
        window.localStorage.removeItem('draft_text-' + JSINFO.id);
        window.localStorage.removeItem('draft_date-' + JSINFO.id);
    },

    /**
     * Save the current page in the local draft
     */
    saveDraft: function () {
        console.log('sving draft');

        var page =
            localdraft.$form.find('input[name=id]').val();

        var state =
            localdraft.$form.find('input[name=prefix]').val() +
            localdraft.$form.find('textarea[name=wikitext]').val() +
            localdraft.$form.find('input[name=suffix]').val();

        var date =
            localdraft.$form.find('input[name=date]').val();

        window.localStorage.setItem('draft_text-' + page, state);
        window.localStorage.setItem('draft_date-' + page, date);

    },

    /**
     * Saves the locally stored draft (if any) to the server
     */
    saveRemoteDraft: function () {
        console.log('getDraft' + JSINFO.id);

        var draft_text = window.localStorage.getItem('draft_text-' + JSINFO.id);
        var draft_date = window.localStorage.getItem('draft_date-' + JSINFO.id);

        if (draft_date && draft_text) {
            var params = {
                'call':     'lock',
                'id':       JSINFO.id,
                'prefix':   '',
                'wikitext': draft_text,
                'suffix':   '',
                'date':     draft_date
            };

            jQuery.post(
                    DOKU_BASE + 'lib/exe/ajax.php',
                params,
                localdraft.onRemoteDraftSave(),
                'html'
            );

        }
    },

    /**
     * Callback when the data has been saved
     * @param data
     */
    onRemoteDraftSave: function (data) {
        localdraft.removeDraft();
        // page's draft status might have changed, reload
        document.location.reload();
    }
};

jQuery(localdraft.init);