/
app.js
78 lines (57 loc) · 1.53 KB
/
app.js
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
/*!
© Nick Freear, 12-June-2019 | License: MIT.
*/
((WIN, DOC) => {
'use strict';
const DEFAULTS = {
el: '#app',
vuejs: 'https://unpkg.com/vue/dist/vue.js',
timeout: 6 * 1000,
itemCount: 10
};
let CFG = {};
WIN.OneLine = (options) => {
CFG = Object.assign(DEFAULTS, options);
let promise = new Promise((resolve, reject) => {
let sc = DOC.createElement('script');
DOC.body.appendChild(sc);
sc.onload = () => resolve(mountVue);
sc.src = CFG.vuejs;
WIN.setTimeout(() => reject(Error("OneLine: script 'onload' failed.")), CFG.timeout);
});
return promise;
};
function mountVue () {
const Vue = WIN.Vue;
let vm = new Vue({
el: CFG.el,
data () {
return {
itemCount: CFG.itemCount
// items: [],
// reverseItems: [],
};
},
computed: {
items () {
let theItems = [];
const MAKE_ARRAY = Array.from(Array(this.itemCount).keys());
MAKE_ARRAY.forEach((name, id) => theItems.push({ id, name }));
console.debug('OneLine.items:', theItems);
return theItems;
},
reverseItems () {
return this.items.reverse();
}
},
methods: {
oldebug (...values) { console.warn(...values); }
},
mounted () {
console.debug('OneLine.mounted:', Vue.version, Vue.config, CFG, this);
}
});
return vm;
} // End: mountVue()
console.debug('OneLine: end');
})(window, window.document);