Artifact
b55dab519ee13644a84f67b6b41b704f607425ee7db0066f30c787143789f1d0:
0000: 63 6f 6e 73 74 20 74 6d 70 6c 20 3d 20 60 0a 20 const tmpl = `.
0010: 20 3c 64 69 76 3e 0a 20 20 20 20 3c 64 69 76 20 <div>. <div
0020: 72 65 66 3d 22 69 74 65 6d 73 22 20 65 61 63 68 ref="items" each
0030: 3d 22 7b 20 69 74 65 6d 20 69 6e 20 69 74 65 6d ="{ item in item
0040: 73 20 7d 22 3e 0a 20 20 20 20 20 20 7b 20 69 74 s }">. { it
0050: 65 6d 2e 6e 61 6d 65 20 7d 0a 20 20 20 20 20 20 em.name }.
0060: 3c 70 20 65 61 63 68 3d 22 7b 20 70 72 6f 70 20 <p each="{ prop
0070: 69 6e 20 69 74 65 6d 2e 70 72 6f 70 73 20 7d 22 in item.props }"
0080: 3e 0a 20 20 20 20 20 20 20 20 7b 20 70 72 6f 70 >. { prop
0090: 2e 6e 61 6d 65 20 7d 0a 20 20 20 20 20 20 3c 2f .name }. </
00a0: 70 3e 0a 20 20 20 20 3c 2f 64 69 76 3e 0a 20 20 p>. </div>.
00b0: 3c 2f 64 69 76 3e 0a 60 0a 0a 6d 6f 64 75 6c 65 </div>.`..module
00c0: 2e 65 78 70 6f 72 74 73 20 3d 20 66 75 6e 63 74 .exports = funct
00d0: 69 6f 6e 28 73 75 69 74 65 2c 20 74 65 73 74 4e ion(suite, testN
00e0: 61 6d 65 2c 20 72 69 6f 74 29 20 7b 0a 20 20 66 ame, riot) {. f
00f0: 75 6e 63 74 69 6f 6e 20 67 65 6e 65 72 61 74 65 unction generate
0100: 49 74 65 6d 73 28 61 6d 6f 75 6e 74 2c 20 68 61 Items(amount, ha
0110: 73 43 68 69 6c 64 72 65 6e 29 20 7b 0a 20 20 20 sChildren) {.
0120: 20 76 61 72 20 69 74 65 6d 73 20 3d 20 5b 5d 0a var items = [].
0130: 20 20 20 20 77 68 69 6c 65 20 28 61 6d 6f 75 6e while (amoun
0140: 74 2d 2d 29 20 7b 0a 20 20 20 20 20 20 69 74 65 t--) {. ite
0150: 6d 73 2e 70 75 73 68 28 7b 0a 20 20 20 20 20 20 ms.push({.
0160: 20 20 6e 61 6d 65 3a 20 60 66 6f 6f 20 24 7b 20 name: `foo ${
0170: 4d 61 74 68 2e 72 61 6e 64 6f 6d 28 29 20 7d 60 Math.random() }`
0180: 2c 0a 20 20 20 20 20 20 20 20 70 72 6f 70 73 3a ,. props:
0190: 20 68 61 73 43 68 69 6c 64 72 65 6e 20 3f 20 67 hasChildren ? g
01a0: 65 6e 65 72 61 74 65 49 74 65 6d 73 28 35 2c 20 enerateItems(5,
01b0: 66 61 6c 73 65 29 20 3a 20 5b 5d 0a 20 20 20 20 false) : [].
01c0: 20 20 7d 29 0a 20 20 20 20 7d 0a 20 20 20 20 72 }). }. r
01d0: 65 74 75 72 6e 20 69 74 65 6d 73 0a 20 20 7d 0a eturn items. }.
01e0: 20 20 6c 65 74 20 74 61 67 0a 0a 20 20 73 75 69 let tag.. sui
01f0: 74 65 0a 20 20 20 20 2e 6f 6e 28 27 73 74 61 72 te. .on('star
0200: 74 27 2c 20 66 75 6e 63 74 69 6f 6e 28 29 20 7b t', function() {
0210: 0a 20 20 20 20 2f 2f 20 73 65 74 75 70 0a 20 20 . // setup.
0220: 20 20 20 20 76 61 72 20 6c 6f 6f 70 54 61 67 20 var loopTag
0230: 3d 20 64 6f 63 75 6d 65 6e 74 2e 63 72 65 61 74 = document.creat
0240: 65 45 6c 65 6d 65 6e 74 28 27 6c 6f 6f 70 2d 74 eElement('loop-t
0250: 61 67 27 29 0a 20 20 20 20 20 20 62 6f 64 79 2e ag'). body.
0260: 61 70 70 65 6e 64 43 68 69 6c 64 28 6c 6f 6f 70 appendChild(loop
0270: 54 61 67 29 0a 20 20 20 20 20 20 72 69 6f 74 2e Tag). riot.
0280: 74 61 67 28 27 6c 6f 6f 70 2d 74 61 67 27 2c 20 tag('loop-tag',
0290: 74 6d 70 6c 2c 20 66 75 6e 63 74 69 6f 6e 28 29 tmpl, function()
02a0: 20 7b 0a 20 20 20 20 20 20 20 20 74 68 69 73 2e {. this.
02b0: 69 74 65 6d 73 20 3d 20 5b 5d 0a 20 20 20 20 20 items = [].
02c0: 20 7d 29 0a 20 20 20 20 20 20 74 61 67 20 3d 20 }). tag =
02d0: 72 69 6f 74 2e 6d 6f 75 6e 74 28 27 6c 6f 6f 70 riot.mount('loop
02e0: 2d 74 61 67 27 29 5b 30 5d 0a 20 20 20 20 7d 29 -tag')[0]. })
02f0: 0a 20 20 20 20 2e 6f 6e 28 27 63 6f 6d 70 6c 65 . .on('comple
0300: 74 65 27 2c 20 66 75 6e 63 74 69 6f 6e 28 29 20 te', function()
0310: 7b 0a 20 20 20 20 20 20 74 61 67 2e 75 6e 6d 6f {. tag.unmo
0320: 75 6e 74 28 29 0a 20 20 20 20 7d 29 0a 20 20 20 unt(). }).
0330: 20 2e 61 64 64 28 74 65 73 74 4e 61 6d 65 2c 20 .add(testName,
0340: 28 29 20 3d 3e 20 7b 0a 20 20 20 20 20 20 74 61 () => {. ta
0350: 67 2e 69 74 65 6d 73 20 3d 20 67 65 6e 65 72 61 g.items = genera
0360: 74 65 49 74 65 6d 73 28 31 30 2c 20 74 72 75 65 teItems(10, true
0370: 29 0a 20 20 20 20 20 20 74 61 67 2e 75 70 64 61 ). tag.upda
0380: 74 65 28 29 0a 20 20 20 20 20 20 74 61 67 2e 69 te(). tag.i
0390: 74 65 6d 73 2e 73 70 6c 69 63 65 28 32 2c 20 31 tems.splice(2, 1
03a0: 29 0a 20 20 20 20 20 20 74 61 67 2e 69 74 65 6d ). tag.item
03b0: 73 2e 73 70 6c 69 63 65 28 34 2c 20 31 29 0a 20 s.splice(4, 1).
03c0: 20 20 20 20 20 74 61 67 2e 69 74 65 6d 73 2e 73 tag.items.s
03d0: 70 6c 69 63 65 28 36 2c 20 31 29 0a 20 20 20 20 plice(6, 1).
03e0: 20 20 74 61 67 2e 69 74 65 6d 73 2e 73 70 6c 69 tag.items.spli
03f0: 63 65 28 39 2c 20 31 29 0a 20 20 20 20 20 20 74 ce(9, 1). t
0400: 61 67 2e 69 74 65 6d 73 20 3d 20 74 61 67 2e 69 ag.items = tag.i
0410: 74 65 6d 73 2e 63 6f 6e 63 61 74 28 67 65 6e 65 tems.concat(gene
0420: 72 61 74 65 49 74 65 6d 73 28 35 2c 20 74 72 75 rateItems(5, tru
0430: 65 29 29 0a 20 20 20 20 20 20 74 61 67 2e 75 70 e)). tag.up
0440: 64 61 74 65 28 29 0a 20 20 20 20 7d 29 0a 0a 7d date(). })..}
0450: 0a 0a ..