+
@@ -40,13 +41,11 @@ export default {
}
},
computed: {
- switchState: function() {
- let switchState = this.checked ? ['is-on'] : ['is-off'];
+ switchStates: function() {
+ let switchStates = ['zan-switch--' + (this.checked ? 'on' : 'off'),
+ 'zan-switch--' + (this.disabled ? 'disabled' : '')];
- if (this.disabled) switchState.push('is-disabled');
- if (this.loading) switchState.push('is-loading');
-
- return switchState;
+ return switchStates;
}
},
methods: {
diff --git a/packages/zanui-css/package.json b/packages/zanui-css/package.json
index 3cfec3a05..41e541d23 100644
--- a/packages/zanui-css/package.json
+++ b/packages/zanui-css/package.json
@@ -1,6 +1,6 @@
{
"name": "@youzan/zanui-css",
- "version": "0.0.7",
+ "version": "0.0.13",
"description": "zanui css.",
"main": "lib/index.css",
"style": "lib/index.css",
diff --git a/packages/zanui-css/src/button.css b/packages/zanui-css/src/button.css
index fa4448687..3010554a5 100644
--- a/packages/zanui-css/src/button.css
+++ b/packages/zanui-css/src/button.css
@@ -75,13 +75,13 @@
font-size: 10px;
}
- @when disabled {
+ @m disabled {
color: $button-disabled-color;
background-color: $button-disabled-background-color;
border: 1px solid $button-disabled-border-color;
}
- @when block {
+ @m block {
display: block;
}
}
diff --git a/packages/zanui-css/src/button_group.css b/packages/zanui-css/src/button_group.css
index 0585ab70b..5d4231493 100644
--- a/packages/zanui-css/src/button_group.css
+++ b/packages/zanui-css/src/button_group.css
@@ -2,6 +2,7 @@
display: inline-block;
box-sizing: border-box;
padding-right: 10px;
+ vertical-align: middle;
&:last-child {
padding-right: 0;
}
diff --git a/packages/zanui-css/src/cell.css b/packages/zanui-css/src/cell.css
index be6bc0b4b..5be52bce1 100644
--- a/packages/zanui-css/src/cell.css
+++ b/packages/zanui-css/src/cell.css
@@ -5,6 +5,7 @@
@b cell-group {
padding-left: 10px;
position: relative;
+ background-color: #fff;
&::after {
@mixin border-retina (top, bottom);
diff --git a/packages/zanui-css/src/icon.css b/packages/zanui-css/src/icon.css
index 7d5daddb7..7847d21f5 100644
--- a/packages/zanui-css/src/icon.css
+++ b/packages/zanui-css/src/icon.css
@@ -63,4 +63,4 @@
.zan-icon-sign:before { content: '\e80d'; } /* '' */
.zan-icon-store:before { content: '\e80e'; } /* '' */
.zan-icon-topay:before { content: '\e80f'; } /* '' */
-.zan-icon-tosend:before { content: '\e810'; } /* '' */
\ No newline at end of file
+.zan-icon-tosend:before { content: '\e810'; } /* '' */
diff --git a/packages/zanui-css/src/loading.css b/packages/zanui-css/src/loading.css
index 4c7ee0d96..c51bdc112 100644
--- a/packages/zanui-css/src/loading.css
+++ b/packages/zanui-css/src/loading.css
@@ -3,16 +3,19 @@
-webkit-transform: rotate(0deg);
transform: rotate(0deg);
}
+
to {
-webkit-transform: rotate(360deg);
transform: rotate(360deg);
}
}
+
@keyframes loading {
from {
-webkit-transform: rotate(0deg);
transform: rotate(0deg);
}
+
to {
-webkit-transform: rotate(360deg);
transform: rotate(360deg);
@@ -25,17 +28,41 @@
height: 30px;
line-height: 0;
font-size: 0;
- }
+
+ @e spinner {
+ display: inline-block;
+ height: 100%;
+ width: 100%;
+
+ -webkit-animation: loading 0.8s linear;
+ -webkit-animation-iteration-count: infinite;
+ animation: loading 0.8s linear;
+ animation-iteration-count: infinite;
- @b spinner {
- display: inline-block;
- height: 100%;
- width: 100%;
- background: url('');
- background-size: contain;
- -webkit-animation: loading 0.8s linear;
- -webkit-animation-iteration-count: infinite;
- animation: loading 0.8s linear;
- animation-iteration-count: infinite;
+ @m circle {
+ border-radius: 100%;
+ border: 3px solid transparent;
+ box-sizing: border-box;
+ &.zan-loading__spinner--black {
+ border-color: $c-gray;
+ border-top-color: $c-gray-darker;
+ }
+ &.zan-loading__spinner--white {
+ border-color: rgba(0, 0, 0, .5);
+ border-top-color: transparent;
+ }
+ }
+
+ @m gradient-circle {
+ &.zan-loading__spinner--black {
+ background: url('');
+ background-size: contain;
+ }
+ &.zan-loading__spinner--white {
+ background: url('');
+ background-size: contain;
+ }
+ }
+ }
}
}
diff --git a/packages/zanui-css/src/steps.css b/packages/zanui-css/src/steps.css
index 8ad4d1937..9c36fc87d 100644
--- a/packages/zanui-css/src/steps.css
+++ b/packages/zanui-css/src/steps.css
@@ -1,5 +1,149 @@
+@import "./common/var.css";
+@import "./mixins/ellipsis.css";
+
@component-namespace zan {
@b steps {
- color: red;
+ overflow: hidden;
+ padding: 0 10px;
+
+ @m 4 {
+ .zan-step {
+ width: 33.2%;
+ }
+ }
+
+ @m 3 {
+ .zan-step {
+ width: 50%;
+ }
+ }
+
+ @e icon {
+ font-size: 40px;
+ line-height: 1;
+ float: left;
+ margin-right: 10px;
+ }
+
+ @e message {
+ display: table;
+ height: 40px;
+ margin: 15px 0;
+
+ .zan-steps__message-wrapper {
+ display: table-cell;
+ vertical-align: middle;
+ }
+ }
+
+ @e title {
+ font-size: 14px;
+ color: $c-black;
+ }
+
+ @e desc {
+ font-size: 12px;
+ line-height: 1.5;
+ color: $c-gray-dark;
+ max-height: 18px;
+ @mixin multi-ellipsis 1;
+ }
+
+ @e items {
+ margin: 0 0 10px;
+ overflow: hidden;
+ padding-bottom: 20px;
+ }
+ }
+
+ @b step {
+ font-size: 14px;
+ float: left;
+ position: relative;
+ color: $c-gray-dark;
+
+ @m finish {
+ color: $c-black;
+
+ .zan-step__circle,
+ .zan-step__line {
+ background-color: $c-green;
+ }
+ }
+
+ @m process {
+ color: $c-black;
+
+ .zan-step__circle-container {
+ top: 24px;
+ }
+
+ .zan-icon {
+ font-size: 12px;
+ color: $c-green;
+ line-height: 1;
+ display: block;
+ }
+ }
+
+ &:first-child {
+ .zan-step__title {
+ transform: none;
+ margin-left: 0;
+ }
+ }
+
+ &:last-child {
+ position: absolute;
+ right: 10px;
+ width: auto;
+
+ .zan-step__title {
+ transform: none;
+ margin-left: 0;
+ }
+
+ .zan-step__circle-container {
+ left: auto;
+ right: -6px;
+ }
+
+ .zan-step__line {
+ width: 0;
+ }
+ }
+
+ .zan-step__circle-container {
+ position: absolute;
+ top: 28px;
+ left: -8px;
+ padding: 0 8px;
+ background-color: #fff;
+ z-index: 1;
+ }
+
+ @e circle {
+ display: block;
+ width: 5px;
+ height: 5px;
+ background-color: #888;
+ border-radius: 50%;
+ }
+
+ @e title {
+ font-size: 12px;
+ transform: translate3d(-50%, 0, 0);
+ display: inline-block;
+ margin-left: 3px;
+ }
+
+ @e line {
+ position: absolute;
+ left: 0px;
+ top: 30px;
+ width: 100%;
+ height: 1px;
+ background-color: $c-gray-light;
+ }
}
}
diff --git a/packages/zanui-css/src/switch.css b/packages/zanui-css/src/switch.css
index 2cf0b1ccf..331581f5b 100644
--- a/packages/zanui-css/src/switch.css
+++ b/packages/zanui-css/src/switch.css
@@ -1,28 +1,32 @@
+@import "./mixins/border_retina.css";
+
@component-namespace zan {
@b switch {
- height: 29px;
- width: 49px;
+ height: 31px;
+ width: 51px;
display: inline-block;
- border-radius: 16px;
position: relative;
- border: 1px solid;
+ background: #fff;
+ border-radius: 16px;
+ &::after{
+ @mixin border-retina (top, right, bottom, left), rgba(0, 0, 0, .1);
+ border-width: 3px;
+ border-radius: 32px;
+ }
@e node {
- width: 27px;
- height: 27px;
- border-radius: 100%;
+ width: 28px;
+ height: 28px;
+ border-radius: 13.5px;
background-color: #fff;
- border: .5px solid rgba(0, 0, 0, .1);
position: absolute;
box-shadow: 0 3px 1px 0 rgba(0, 0, 0, .05), 0 2px 2px 0 rgba(0, 0, 0, .1), 0 3px 3px 0 rgba(0, 0, 0, .05);
- @when on {
- left: 20px;
- transition: all .5s ease-in-out;
- }
-
- @when off {
- left: 0;
- transition: all .5s ease-in-out;
+ left: 1px;
+ top: 1px;
+ z-index: 2;
+ &::after {
+ @mixin border-retina (top, right, bottom, left), rgba(0, 0, 0, .1);
+ border-radius: 27px;
}
}
@@ -35,17 +39,20 @@
transform: translate3d(-50%, -50%, 0);
}
- @when on {
+ @m on {
background-color: #44db5e;
- border-color: #44db5e;
+ &::after { border-color: #44db5e; }
+ .zan-switch__node {
+ transform: translateX(20px);
+ }
}
- @when off {
+ @m off {
background-color: #fff;
border-color: rgba(0, 0, 0, .1);
}
- @when disabled {
+ @m disabled {
opacity: .4;
}
}
diff --git a/src/index.js b/src/index.js
index 4455a8cb0..4005790e7 100644
--- a/src/index.js
+++ b/src/index.js
@@ -20,6 +20,8 @@ import CheckboxGroup from '../packages/checkbox-group/index.js';
import BadgeGroup from '../packages/badge-group/index.js';
import Badge from '../packages/badge/index.js';
import Search from '../packages/search/index.js';
+import Step from '../packages/step/index.js';
+import ImagePreview from '../packages/image-preview/index.js';
const install = function(Vue) {
if (install.installed) return;
@@ -44,6 +46,8 @@ const install = function(Vue) {
Vue.component(BadgeGroup.name, BadgeGroup);
Vue.component(Badge.name, Badge);
Vue.component(Search.name, Search);
+ Vue.component(Step.name, Step);
+ Vue.component(ImagePreview.name, ImagePreview);
};
// auto install
@@ -53,7 +57,7 @@ if (typeof window !== 'undefined' && window.Vue) {
module.exports = {
install,
- version: '0.0.7',
+ version: '0.0.13',
Button,
Switch,
Field,
@@ -75,5 +79,7 @@ module.exports = {
CheckboxGroup,
BadgeGroup,
Badge,
- Search
+ Search,
+ Step,
+ ImagePreview
};
diff --git a/src/mixins/popup/index.js b/src/mixins/popup/index.js
index 7e929d251..db8870947 100644
--- a/src/mixins/popup/index.js
+++ b/src/mixins/popup/index.js
@@ -1,4 +1,3 @@
-import Vue from 'vue';
import merge from 'src/utils/merge';
import PopupManager from './popup-manager';
diff --git a/src/mixins/popup/popup-manager.js b/src/mixins/popup/popup-manager.js
index 35e56cdcb..737b9b9f3 100644
--- a/src/mixins/popup/popup-manager.js
+++ b/src/mixins/popup/popup-manager.js
@@ -1,6 +1,6 @@
-import { addClass, removeClass } from 'src/utils/dom';
+import { addClass } from 'src/utils/dom';
-let hasModal = false;
+let hasModal = false; // eslint-disable-line
const getModal = function() {
let modalDom = PopupManager.modalDom;
diff --git a/test/unit/specs/switch.spec.js b/test/unit/specs/switch.spec.js
index 5e529d42a..176d69ead 100644
--- a/test/unit/specs/switch.spec.js
+++ b/test/unit/specs/switch.spec.js
@@ -14,7 +14,7 @@ describe('Switch', () => {
vm.mount();
expect(vm.el.classList.contains('zan-switch')).to.true;
- expect(vm.el.classList.contains('is-on')).to.true;
+ expect(vm.el.classList.contains('zan-switch--on')).to.true;
});
it('create off switch', () => {
@@ -42,11 +42,11 @@ describe('Switch', () => {
});
vm.mount();
expect(vm.el.classList.contains('zan-switch')).to.true;
- expect(vm.el.classList.contains('is-off')).to.true;
+ expect(vm.el.classList.contains('zan-switch--off')).to.true;
vm.el.click();
setTimeout(() => {
- expect(vm.el.classList.contains('is-off')).to.true;
+ expect(vm.el.classList.contains('zan-switch--off')).to.true;
done();
});
});
@@ -72,11 +72,11 @@ describe('Switch', () => {
});
vm.mount();
expect(vm.el.classList.contains('zan-switch')).to.true;
- expect(vm.el.classList.contains('is-off')).to.true;
+ expect(vm.el.classList.contains('zan-switch--off')).to.true;
vm.el.click();
setTimeout(() => {
- expect(vm.el.classList.contains('is-on')).to.true;
+ expect(vm.el.classList.contains('zan-switch--on')).to.true;
done();
});
});