compiler-mp-alipay.spec.js 8.8 KB
Newer Older
fxy060608's avatar
fxy060608 已提交
1 2
const compiler = require('../lib')

fxy060608's avatar
fxy060608 已提交
3
function assertCodegen (template, templateCode, renderCode = 'with(this){}', options = {}) {
fxy060608's avatar
fxy060608 已提交
4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20
  const res = compiler.compile(template, {
    resourcePath: 'test.wxml',
    mp: Object.assign({
      minified: true,
      isTest: true,
      platform: 'mp-alipay'
    }, options)
  })

  expect(res.template).toBe(templateCode)
  expect(res.render).toBe(renderCode)
}

describe('mp:compiler-mp-alipay', () => {
  it('generate v-for directive', () => {
    assertCodegen(
      '<view><view v-for="(item,index) in items" :key="index"></view></view>',
fxy060608's avatar
fxy060608 已提交
21
      '<view><block a:for="{{items}}" a:for-item="item" a:for-index="index" a:key="index"><view></view></block></view>'
fxy060608's avatar
fxy060608 已提交
22 23 24 25 26 27
    )
  })

  it('generate v-else-if with v-else directive', () => {
    assertCodegen(
      '<view><view v-if="show">hello</view><view v-else-if="hide">world</view><view v-else>bye</view></view>',
fxy060608's avatar
fxy060608 已提交
28
      '<view><block a:if="{{show}}"><view>hello</view></block><block a:else><block a:if="{{hide}}"><view>world</view></block><block a:else><view>bye</view></block></block></view>'
fxy060608's avatar
fxy060608 已提交
29
    )
fxy060608's avatar
fxy060608 已提交
30 31 32 33
  })
  it('generate ref', () => {
    assertCodegen(
      '<component1 ref="c1">text</component1>',
fxy060608's avatar
fxy060608 已提交
34
      '<component1 vue-id="551070e6-1" ref="__r" data-ref="c1" onVueInit="__l">text</component1>'
fxy060608's avatar
fxy060608 已提交
35 36 37
    )
    assertCodegen(
      '<component1 :ref="c2">text<text>123213</text></component1>',
fxy060608's avatar
fxy060608 已提交
38
      '<component1 vue-id="551070e6-1" ref="__r" data-ref="{{c2}}" onVueInit="__l">text<text>123213</text></component1>'
fxy060608's avatar
fxy060608 已提交
39 40 41
    )
    assertCodegen(
      '<component1 v-for="item in items" ref="c3"></component1>',
fxy060608's avatar
fxy060608 已提交
42
      '<block a:for="{{items}}" a:for-item="item" a:for-index="__i0__"><component1 vue-id="{{\'551070e6-1-\'+__i0__}}" ref="__r" data-ref-in-for="c3" onVueInit="__l"></component1></block>'
fxy060608's avatar
fxy060608 已提交
43 44 45
    )
    assertCodegen(
      '<component1 v-for="item in items" :ref="c4"></component1>',
fxy060608's avatar
fxy060608 已提交
46
      '<block a:for="{{items}}" a:for-item="item" a:for-index="__i0__"><component1 vue-id="{{\'551070e6-1-\'+__i0__}}" ref="__r" data-ref-in-for="{{c4}}" onVueInit="__l"></component1></block>'
fxy060608's avatar
fxy060608 已提交
47
    )
fxy060608's avatar
fxy060608 已提交
48 49 50 51
  })
  it('generate default slot', () => {
    assertCodegen(
      '<component1>text</component1>',
fxy060608's avatar
fxy060608 已提交
52
      '<component1 vue-id="551070e6-1" onVueInit="__l">text</component1>'
fxy060608's avatar
fxy060608 已提交
53 54 55
    )
    assertCodegen(
      '<component1>text<text>123213</text></component1>',
fxy060608's avatar
fxy060608 已提交
56
      '<component1 vue-id="551070e6-1" onVueInit="__l">text<text>123213</text></component1>'
fxy060608's avatar
fxy060608 已提交
57 58 59
    )
    assertCodegen(
      '<component1>text<block slot="right"></block></component1>',
fxy060608's avatar
fxy060608 已提交
60
      '<component1 vue-id="551070e6-1" onVueInit="__l">text<view slot="right"></view></component1>'
fxy060608's avatar
fxy060608 已提交
61 62
    )
  })
63 64 65 66 67 68 69 70 71 72 73 74

  it('generate scoped slot', () => {
    assertCodegen(
      '<component1 :text="\'text\'"><template v-slot="props"><view :class="{text:props.text}">{{props.text}}</view></template></component1>',
      '<component1 vue-id="551070e6-1" text="text" onVueInit="__l"><view slot="default" slot-scope="props"><view class="{{((props.text)?\'text\':\'\')}}">{{props.text}}</view></view></component1>'
    )
    assertCodegen(
      '<component1 :text="\'text\'"><template v-slot="{text}"><view :class="{text:text}">{{text}}</view></template></component1>',
      '<component1 vue-id="551070e6-1" text="text" onVueInit="__l"><view slot="default" slot-scope="__SCOPED__"><view class="{{((__SCOPED__.text)?\'text\':\'\')}}">{{__SCOPED__.text}}</view></view></component1>'
    )
  })

fxy060608's avatar
fxy060608 已提交
75 76 77
  it('generate class binding', () => {
    assertCodegen(
      '<div :class="{ active: isActive }">1</div>',
fxy060608's avatar
fxy060608 已提交
78
      '<view class="{{((\'_div\')+\' \'+((isActive)?\'active\':\'\'))}}">1</view>'
fxy060608's avatar
fxy060608 已提交
79 80
    )
    assertCodegen(
fxy060608's avatar
fxy060608 已提交
81 82
      '<p class="static" :class="{ active: isActive, \'text-danger\': hasError }">2</p>',
      '<view class="{{(((\'static _p\')+\' \'+((isActive)?\'active\':\'\'))+\' \'+((hasError)?\'text-danger\':\'\'))}}">2</view>'
fxy060608's avatar
fxy060608 已提交
83 84 85
    )
    assertCodegen(
      '<p class="static" :class="[activeClass, errorClass]">3</p>',
fxy060608's avatar
fxy060608 已提交
86
      '<view class="{{(((\'static _p\')+\' \'+activeClass)+\' \'+errorClass)}}">3</view>'
fxy060608's avatar
fxy060608 已提交
87 88
    )
    assertCodegen(
fxy060608's avatar
fxy060608 已提交
89 90
      '<p class="static" :class="[isActive ? activeClass : \'\', errorClass]">4</p>',
      '<view class="{{(((\'static _p\')+\' \'+(isActive?activeClass:\'\'))+\' \'+errorClass)}}">4</view>'
fxy060608's avatar
fxy060608 已提交
91 92
    )
    assertCodegen(
fxy060608's avatar
fxy060608 已提交
93 94
      '<p class="static" :class="[{ active: isActive }, errorClass]">5</p>',
      '<view class="{{(((\'static _p\')+\' \'+[(isActive)?\'active\':\'\'])+\' \'+errorClass)}}">5</view>'
fxy060608's avatar
fxy060608 已提交
95 96
    )
    assertCodegen(
fxy060608's avatar
fxy060608 已提交
97 98
      '<div class="container" :class="computedClassObject">6</div>',
      '<view class="{{((\'container _div\')+\' \'+computedClassObject)}}">6</view>'
fxy060608's avatar
fxy060608 已提交
99 100 101 102 103 104 105
    )
    //     assertCodegen(
    //       `<div class="container" :class="computedClassObject">6</div>`,
    //       `<view class="{{$root.c0}}">6</view>`,
    //       `with(this){var c0=__get_class(computedClassObject,"container");$mp.data=Object.assign({},{$root:{c0:c0}})}`
    //     )
    assertCodegen(
fxy060608's avatar
fxy060608 已提交
106 107
      '<p :class="index === currentIndex ? activeClass : itemClass">7</p>',
      '<view class="{{((\'_p\')+\' \'+(index===currentIndex?activeClass:itemClass))}}">7</view>'
fxy060608's avatar
fxy060608 已提交
108 109
    )
    assertCodegen(
fxy060608's avatar
fxy060608 已提交
110 111
      '<p :class="\'m-content-head-\'+message.user">8</p>',
      '<view class="{{((\'_p\')+\' \'+(\'m-content-head-\'+message.user))}}">8</view>'
fxy060608's avatar
fxy060608 已提交
112 113
    )
    assertCodegen(
fxy060608's avatar
fxy060608 已提交
114 115
      '<p :class="classStr1 || classStr2" class="bg">9</p>',
      '<view class="{{((\'bg _p\')+\' \'+(classStr1||classStr2))}}">9</view>'
fxy060608's avatar
fxy060608 已提交
116 117 118
    )
  })

fxy060608's avatar
fxy060608 已提交
119 120 121
  it('generate getPhoneNumber', () => {
    assertCodegen(
      '<button open-type="getPhoneNumber" @getphonenumber="getPhoneNumber">获取手机号</button>',
fxy060608's avatar
fxy060608 已提交
122
      '<button open-type="getAuthorize" scope="phoneNumber" data-event-opts="{{[[\'getAuthorize\',[[\'$onAliGetAuthorize\',[\'getPhoneNumber\',\'$event\']]]],[\'error\',[[\'$onAliAuthError\',[\'getPhoneNumber\',\'$event\']]]]]}}" onGetAuthorize="__e" onError="__e">获取手机号</button>'
fxy060608's avatar
fxy060608 已提交
123 124 125
    )
  })

fxy060608's avatar
fxy060608 已提交
126 127
  it('generate events with v-on directive', () => {
    assertCodegen(
fxy060608's avatar
fxy060608 已提交
128 129 130
      '<uni-list-item title="标题文字" note="描述信息" show-extra-icon="true" :extra-icon="{color: \'#4cd964\',size: \'22\',type: \'spinner\'}"></uni-list-item>',
      '<uni-list-item vue-id="551070e6-1" title="标题文字" note="描述信息" show-extra-icon="true" extra-icon="{{$root.a0}}" onVueInit="__l"></uni-list-item>',
      'with(this){var a0={color:"#4cd964",size:"22",type:"spinner"};$mp.data=Object.assign({},{$root:{a0:a0}})}'
fxy060608's avatar
fxy060608 已提交
131 132 133
    )

    assertCodegen(
fxy060608's avatar
fxy060608 已提交
134 135
      '<view @click="onClick" @touchstart="onTouchStart" @touchmove="onTouchMove" @touchend="onTouchEnd" @touchcancel="onTouchCancel" @longtap="onLongTap" @longpress="onLongPress"></view>',
      '<view data-event-opts="{{[[\'tap\',[[\'onClick\',[\'$event\']]]],[\'touchStart\',[[\'onTouchStart\',[\'$event\']]]],[\'touchMove\',[[\'onTouchMove\',[\'$event\']]]],[\'touchEnd\',[[\'onTouchEnd\',[\'$event\']]]],[\'touchCancel\',[[\'onTouchCancel\',[\'$event\']]]],[\'longTap\',[[\'onLongTap\',[\'$event\']]]],[\'longTap\',[[\'onLongPress\',[\'$event\']]]]]}}" onTap="__e" onTouchStart="__e" onTouchMove="__e" onTouchEnd="__e" onTouchCancel="__e" onLongTap="__e"></view>'
fxy060608's avatar
fxy060608 已提交
136 137 138
    )

    assertCodegen(
fxy060608's avatar
fxy060608 已提交
139 140
      '<form @submit="formSubmit" @reset="formReset"/>',
      '<form data-event-opts="{{[[\'submit\',[[\'formSubmit\',[\'$event\']]]]]}}" onSubmit="__e" onReset="formReset"></form>'
fxy060608's avatar
fxy060608 已提交
141 142 143
    )

    assertCodegen(
fxy060608's avatar
fxy060608 已提交
144 145
      '<map @callouttap="calloutTap" @controltap="controlTap" @markertap="markerTap" @regionchange="regionChange" @tap="tap"/>',
      '<map data-event-opts="{{[[\'tap\',[[\'tap\',[\'$event\']]]]]}}" onCalloutTap="calloutTap" onControlTap="controlTap" onMarkerTap="markerTap" onRegionChange="regionChange" onTap="__e"></map>'
fxy060608's avatar
fxy060608 已提交
146 147 148
    )

    assertCodegen(
fxy060608's avatar
fxy060608 已提交
149 150
      '<view @transitionend="transitionEnd" @animationstart="animationStart" @animationiteration="animationIteration" @animationend="animationEnd" @firstappear="firstAppear"/>',
      '<view data-event-opts="{{[[\'transitionEnd\',[[\'transitionEnd\',[\'$event\']]]],[\'animationStart\',[[\'animationStart\',[\'$event\']]]],[\'animationIteration\',[[\'animationIteration\',[\'$event\']]]],[\'animationEnd\',[[\'animationEnd\',[\'$event\']]]],[\'firstAppear\',[[\'firstAppear\',[\'$event\']]]]]}}" onTransitionEnd="__e" onAnimationStart="__e" onAnimationIteration="__e" onAnimationEnd="__e" onFirstAppear="__e"></view>'
fxy060608's avatar
fxy060608 已提交
151 152 153
    )

    assertCodegen(
fxy060608's avatar
fxy060608 已提交
154 155
      '<scroll-view @scrolltoupper="scrollToUpper" @scrolltolower="scrollToLower"/>',
      '<scroll-view data-event-opts="{{[[\'scrollToUpper\',[[\'scrollToUpper\',[\'$event\']]]],[\'scrollToLower\',[[\'scrollToLower\',[\'$event\']]]]]}}" onScrollToUpper="__e" onScrollToLower="__e"></scroll-view>'
fxy060608's avatar
fxy060608 已提交
156 157 158
    )

    assertCodegen(
fxy060608's avatar
fxy060608 已提交
159 160
      '<movable-view @changeend="changeEnd"/>',
      '<movable-view data-event-opts="{{[[\'changeEnd\',[[\'changeEnd\',[\'$event\']]]]]}}" onChangeEnd="__e"></movable-view>'
fxy060608's avatar
fxy060608 已提交
161 162
    )
  })
163
})