⌈⌋ ⎇ branch:  Bitrhythm


Hex Artifact Content

Artifact d7fb44a4a12ba7c645f9418b4ec0514d0b354a4684571594a65068e459c381bb:


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 20 6e 6f 2d 72 65 6f 72 64 65 72 3e  s }" no-reorder>
0050: 0a 20 20 20 20 20 20 7b 20 69 74 65 6d 2e 6e 61  .      { item.na
0060: 6d 65 20 7d 0a 20 20 20 20 20 20 3c 70 20 65 61  me }.      <p ea
0070: 63 68 3d 22 7b 20 70 72 6f 70 20 69 6e 20 69 74  ch="{ prop in it
0080: 65 6d 2e 70 72 6f 70 73 20 7d 22 20 6e 6f 2d 72  em.props }" no-r
0090: 65 6f 72 64 65 72 3e 0a 20 20 20 20 20 20 20 20  eorder>.        
00a0: 7b 20 70 72 6f 70 2e 6e 61 6d 65 20 7d 0a 20 20  { prop.name }.  
00b0: 20 20 20 20 3c 2f 70 3e 0a 20 20 20 20 3c 2f 64      </p>.    </d
00c0: 69 76 3e 0a 20 20 3c 2f 64 69 76 3e 0a 60 0a 0a  iv>.  </div>.`..
00d0: 6d 6f 64 75 6c 65 2e 65 78 70 6f 72 74 73 20 3d  module.exports =
00e0: 20 66 75 6e 63 74 69 6f 6e 28 73 75 69 74 65 2c   function(suite,
00f0: 20 74 65 73 74 4e 61 6d 65 2c 20 72 69 6f 74 29   testName, riot)
0100: 20 7b 0a 20 20 66 75 6e 63 74 69 6f 6e 20 67 65   {.  function ge
0110: 6e 65 72 61 74 65 49 74 65 6d 73 28 61 6d 6f 75  nerateItems(amou
0120: 6e 74 2c 20 68 61 73 43 68 69 6c 64 72 65 6e 29  nt, hasChildren)
0130: 20 7b 0a 20 20 20 20 76 61 72 20 69 74 65 6d 73   {.    var items
0140: 20 3d 20 5b 5d 0a 20 20 20 20 77 68 69 6c 65 20   = [].    while 
0150: 28 61 6d 6f 75 6e 74 2d 2d 29 20 7b 0a 20 20 20  (amount--) {.   
0160: 20 20 20 69 74 65 6d 73 2e 70 75 73 68 28 7b 0a     items.push({.
0170: 20 20 20 20 20 20 20 20 6e 61 6d 65 3a 20 27 66          name: 'f
0180: 6f 6f 27 2c 0a 20 20 20 20 20 20 20 20 70 72 6f  oo',.        pro
0190: 70 73 3a 20 68 61 73 43 68 69 6c 64 72 65 6e 20  ps: hasChildren 
01a0: 3f 20 67 65 6e 65 72 61 74 65 49 74 65 6d 73 28  ? generateItems(
01b0: 35 2c 20 66 61 6c 73 65 29 20 3a 20 5b 5d 0a 20  5, false) : []. 
01c0: 20 20 20 20 20 7d 29 0a 20 20 20 20 7d 0a 20 20       }).    }.  
01d0: 20 20 72 65 74 75 72 6e 20 69 74 65 6d 73 0a 20    return items. 
01e0: 20 7d 0a 0a 20 20 6c 65 74 20 74 61 67 0a 20 20   }..  let tag.  
01f0: 73 75 69 74 65 0a 20 20 20 20 2e 6f 6e 28 27 73  suite.    .on('s
0200: 74 61 72 74 27 2c 20 66 75 6e 63 74 69 6f 6e 28  tart', function(
0210: 29 20 7b 0a 20 20 20 20 20 20 76 61 72 20 6c 6f  ) {.      var lo
0220: 6f 70 54 61 67 20 3d 20 64 6f 63 75 6d 65 6e 74  opTag = document
0230: 2e 63 72 65 61 74 65 45 6c 65 6d 65 6e 74 28 27  .createElement('
0240: 6c 6f 6f 70 2d 74 61 67 2d 6e 6f 2d 72 65 6f 72  loop-tag-no-reor
0250: 64 65 72 27 29 0a 20 20 20 20 20 20 62 6f 64 79  der').      body
0260: 2e 61 70 70 65 6e 64 43 68 69 6c 64 28 6c 6f 6f  .appendChild(loo
0270: 70 54 61 67 29 0a 20 20 20 20 20 20 72 69 6f 74  pTag).      riot
0280: 2e 74 61 67 28 27 6c 6f 6f 70 2d 74 61 67 2d 6e  .tag('loop-tag-n
0290: 6f 2d 72 65 6f 72 64 65 72 27 2c 20 74 6d 70 6c  o-reorder', tmpl
02a0: 2c 20 66 75 6e 63 74 69 6f 6e 28 29 20 7b 0a 20  , function() {. 
02b0: 20 20 20 20 20 20 20 74 68 69 73 2e 69 74 65 6d         this.item
02c0: 73 20 3d 20 5b 5d 0a 20 20 20 20 20 20 7d 29 0a  s = [].      }).
02d0: 20 20 20 20 20 20 74 61 67 20 3d 20 72 69 6f 74        tag = riot
02e0: 2e 6d 6f 75 6e 74 28 27 6c 6f 6f 70 2d 74 61 67  .mount('loop-tag
02f0: 2d 6e 6f 2d 72 65 6f 72 64 65 72 27 29 5b 30 5d  -no-reorder')[0]
0300: 0a 20 20 20 20 7d 29 0a 20 20 20 20 2e 6f 6e 28  .    }).    .on(
0310: 27 63 6f 6d 70 6c 65 74 65 27 2c 20 66 75 6e 63  'complete', func
0320: 74 69 6f 6e 28 29 20 7b 0a 20 20 20 20 20 20 74  tion() {.      t
0330: 61 67 2e 75 6e 6d 6f 75 6e 74 28 29 0a 20 20 20  ag.unmount().   
0340: 20 7d 29 0a 20 20 20 20 2e 61 64 64 28 74 65 73   }).    .add(tes
0350: 74 4e 61 6d 65 2c 20 28 29 20 3d 3e 20 7b 0a 20  tName, () => {. 
0360: 20 20 20 20 20 74 61 67 2e 69 74 65 6d 73 20 3d       tag.items =
0370: 20 67 65 6e 65 72 61 74 65 49 74 65 6d 73 28 31   generateItems(1
0380: 30 2c 20 74 72 75 65 29 0a 20 20 20 20 20 20 74  0, true).      t
0390: 61 67 2e 75 70 64 61 74 65 28 29 0a 20 20 20 20  ag.update().    
03a0: 20 20 74 61 67 2e 69 74 65 6d 73 2e 73 70 6c 69    tag.items.spli
03b0: 63 65 28 32 2c 20 31 29 0a 20 20 20 20 20 20 74  ce(2, 1).      t
03c0: 61 67 2e 69 74 65 6d 73 2e 73 70 6c 69 63 65 28  ag.items.splice(
03d0: 34 2c 20 31 29 0a 20 20 20 20 20 20 74 61 67 2e  4, 1).      tag.
03e0: 69 74 65 6d 73 2e 73 70 6c 69 63 65 28 36 2c 20  items.splice(6, 
03f0: 31 29 0a 20 20 20 20 20 20 74 61 67 2e 69 74 65  1).      tag.ite
0400: 6d 73 2e 73 70 6c 69 63 65 28 39 2c 20 31 29 0a  ms.splice(9, 1).
0410: 20 20 20 20 20 20 74 61 67 2e 69 74 65 6d 73 20        tag.items 
0420: 3d 20 74 61 67 2e 69 74 65 6d 73 2e 63 6f 6e 63  = tag.items.conc
0430: 61 74 28 67 65 6e 65 72 61 74 65 49 74 65 6d 73  at(generateItems
0440: 28 35 2c 20 74 72 75 65 29 29 0a 20 20 20 20 20  (5, true)).     
0450: 20 74 61 67 2e 75 70 64 61 74 65 28 29 0a 20 20   tag.update().  
0460: 20 20 7d 29 0a 0a 7d 0a 0a                         })..}..