[improvement] vue style component options (#523)

This commit is contained in:
neverland 2018-09-07 10:24:19 +08:00 committed by GitHub
parent 1f06c97a37
commit a297dba84c
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
45 changed files with 251 additions and 387 deletions

View File

@ -1,5 +1,3 @@
@import "./dist/common/index.wxss";
page { page {
color: #333; color: #333;
background: #f8f8f8; background: #f8f8f8;

View File

@ -1,9 +1,7 @@
Component({ import { create } from '../common/create';
options: {
addGlobalClass: true
},
properties: { create({
props: {
show: Boolean, show: Boolean,
title: String, title: String,
cancelText: String, cancelText: String,
@ -26,16 +24,16 @@ Component({
const { index } = event.currentTarget.dataset; const { index } = event.currentTarget.dataset;
const item = this.data.actions[index]; const item = this.data.actions[index];
if (item && !item.disabled && !item.loading) { if (item && !item.disabled && !item.loading) {
this.triggerEvent('select', item); this.$emit('select', item);
} }
}, },
onCancel() { onCancel() {
this.triggerEvent('cancel'); this.$emit('cancel');
}, },
onClose() { onClose() {
this.triggerEvent('close'); this.$emit('close');
} }
} }
}); });

View File

@ -1,14 +1,8 @@
const BADGE_PATH = '../badge/index'; import { create } from '../common/create';
Component({
options: {
addGlobalClass: true
},
externalClasses: ['custom-class'],
create({
relations: { relations: {
[BADGE_PATH]: { '../badge/index': {
type: 'descendant', type: 'descendant',
linked(target) { linked(target) {
@ -23,13 +17,11 @@ Component({
} }
}, },
properties: { props: {
active: { active: {
type: Number, type: Number,
value: 0, value: 0,
observer() { observer: 'setActive'
this.setActive();
}
} }
}, },
@ -53,7 +45,7 @@ Component({
} }
if (this.currentActive !== -1) { if (this.currentActive !== -1) {
this.triggerEvent('change', active); this.$emit('change', active);
} }
this.currentActive = active; this.currentActive = active;

View File

@ -1,26 +1,20 @@
const BADGE_GROUP_PATH = '../badge-group/index'; import { create } from '../common/create';
Component({
options: {
addGlobalClass: true
},
externalClasses: ['custom-class'],
create({
relations: { relations: {
[BADGE_GROUP_PATH]: { '../badge-group/index': {
type: 'ancestor' type: 'ancestor'
} }
}, },
properties: { props: {
info: Number, info: Number,
title: String title: String
}, },
methods: { methods: {
onClick() { onClick() {
const group = this.getRelationNodes(BADGE_GROUP_PATH)[0]; const group = this.getRelationNodes('../badge-group/index')[0];
if (group) { if (group) {
group.setActive(this); group.setActive(this);
} }

View File

@ -1,21 +1,16 @@
import buttonBehaviors from '../behaviors/button'; import { create } from '../common/create';
import classnames from '../common/classnames'; import { classNames } from '../common/class-names';
import { button } from '../mixins/button';
const booleanProp = { const booleanProp = {
type: Boolean, type: Boolean,
observer: 'setClasses' observer: 'setClasses'
}; };
Component({ create({
options: { mixins: [button],
addGlobalClass: true
},
externalClasses: ['custom-class', 'loading-class'], props: {
behaviors: [buttonBehaviors],
properties: {
type: { type: {
type: String, type: String,
value: 'default', value: 'default',
@ -40,14 +35,14 @@ Component({
methods: { methods: {
onClick() { onClick() {
if (!this.data.disabled && !this.data.loading) { if (!this.data.disabled && !this.data.loading) {
this.triggerEvent('click'); this.$emit('click');
} }
}, },
setClasses() { setClasses() {
const { type, size, plain, disabled, loading, square, block } = this.data; const { type, size, plain, disabled, loading, square, block } = this.data;
this.setData({ this.setData({
classes: classnames(`van-button--${type}`, `van-button--${size}`, { classes: classNames(`van-button--${type}`, `van-button--${size}`, {
'van-button--block': block, 'van-button--block': block,
'van-button--plain': plain, 'van-button--plain': plain,
'van-button--square': square, 'van-button--square': square,

View File

@ -1,11 +1,7 @@
Component({ import { create } from '../common/create';
options: {
multipleSlots: true,
addGlobalClass: true
},
externalClasses: [ create({
'custom-class', classes: [
'thumb-class', 'thumb-class',
'title-class', 'title-class',
'price-class', 'price-class',
@ -13,7 +9,7 @@ Component({
'num-class' 'num-class'
], ],
properties: { props: {
num: String, num: String,
desc: String, desc: String,
thumb: String, thumb: String,

View File

@ -1,11 +1,7 @@
Component({ import { create } from '../common/create';
options: {
addGlobalClass: true
},
externalClasses: ['custom-class'], create({
props: {
properties: {
border: { border: {
type: Boolean, type: Boolean,
value: true value: true

View File

@ -1,6 +1,7 @@
Component({ import { create } from '../common/create';
externalClasses: [
'custom-class', create({
classes: [
'title-class', 'title-class',
'label-class', 'label-class',
'value-class', 'value-class',
@ -8,12 +9,7 @@ Component({
'right-icon-class' 'right-icon-class'
], ],
options: { props: {
multipleSlots: true,
addGlobalClass: true
},
properties: {
title: null, title: null,
value: null, value: null,
url: String, url: String,
@ -42,7 +38,7 @@ Component({
if (url) { if (url) {
wx[this.data.linkType]({ url }); wx[this.data.linkType]({ url });
} }
this.triggerEvent('click'); this.$emit('click');
} }
} }
}); });

View File

@ -1,19 +1,13 @@
const ROW_PATH = '../row/index'; import { create } from '../common/create';
Component({
options: {
addGlobalClass: true
},
externalClasses: ['custom-class'],
create({
relations: { relations: {
[ROW_PATH]: { '../row/index': {
type: 'ancestor' type: 'ancestor'
} }
}, },
properties: { props: {
span: Number, span: Number,
offset: Number offset: Number
}, },

View File

@ -1,6 +1,6 @@
const hasOwn = {}.hasOwnProperty; const hasOwn = {}.hasOwnProperty;
export default function classNames() { export function classNames() {
const classes = []; const classes = [];
for (let i = 0; i < arguments.length; i++) { for (let i = 0; i < arguments.length; i++) {

39
packages/common/create.js Normal file
View File

@ -0,0 +1,39 @@
function $emit() {
this.triggerEvent.apply(this, arguments);
}
export function create(sfc) {
// map props to properties
if (sfc.props) {
sfc.properties = sfc.props;
delete sfc.props;
}
// map mixins to behaviors
if (sfc.mixins) {
sfc.behaviors = sfc.mixins;
delete sfc.mixins;
}
// map field to form-field behavior
if (sfc.field) {
sfc.behaviors = sfc.behaviors || [];
sfc.behaviors.push('wx://form-field');
}
// add default options
sfc.options = sfc.options || {};
sfc.options.multipleSlots = true;
sfc.options.addGlobalClass = true;
// add default externalClasses
sfc.externalClasses = sfc.classes || [];
sfc.externalClasses.push('custom-class');
// add default methods
sfc.methods = sfc.methods || {};
sfc.methods.$emit = $emit;
Component(sfc);
};

View File

@ -1,8 +0,0 @@
/**
* Entry of basic styles
*/
@import "./style/var.pcss";
@import "./style/ellipsis.pcss";
@import "./style/clearfix.pcss";
@import "./style/hairline.pcss";

View File

@ -1,9 +1,7 @@
Component({ import { create } from '../common/create';
options: {
addGlobalClass: true
},
properties: { create({
props: {
title: String, title: String,
message: String, message: String,
useSlot: Boolean, useSlot: Boolean,
@ -79,8 +77,8 @@ Component({
if (!this.data.asyncClose) { if (!this.data.asyncClose) {
this.setData({ show: false }); this.setData({ show: false });
} }
this.triggerEvent('close', action); this.$emit('close', action);
this.triggerEvent(action); this.$emit(action);
} }
} }
}); });

View File

@ -1,16 +1,11 @@
Component({ import { create } from '../common/create';
behaviors: ['wx://form-field'],
externalClasses: [ create({
'input-class' field: true,
],
options: { classes: ['input-class'],
multipleSlots: true,
addGlobalClass: true
},
properties: { props: {
icon: String, icon: String,
label: String, label: String,
error: Boolean, error: Boolean,
@ -68,8 +63,8 @@ Component({
methods: { methods: {
onInput(event) { onInput(event) {
const { value = '' } = event.detail || {}; const { value = '' } = event.detail || {};
this.triggerEvent('input', value); this.$emit('input', value);
this.triggerEvent('change', value); this.$emit('change', value);
this.setData({ this.setData({
value, value,
showClear: this.getShowClear({ value }) showClear: this.getShowClear({ value })
@ -77,7 +72,7 @@ Component({
}, },
onFocus(event) { onFocus(event) {
this.triggerEvent('focus', event); this.$emit('focus', event);
this.setData({ this.setData({
focused: true, focused: true,
showClear: this.getShowClear({ focused: true }) showClear: this.getShowClear({ focused: true })
@ -86,7 +81,7 @@ Component({
onBlur(event) { onBlur(event) {
this.focused = false; this.focused = false;
this.triggerEvent('blur', event); this.$emit('blur', event);
this.setData({ this.setData({
focused: false, focused: false,
showClear: this.getShowClear({ focused: false }) showClear: this.getShowClear({ focused: false })
@ -94,16 +89,15 @@ Component({
}, },
onClickIcon() { onClickIcon() {
this.triggerEvent('click-icon'); this.$emit('click-icon');
}, },
getShowClear(options) { getShowClear(options) {
const { const { focused = this.data.focused, value = this.data.value } = options;
focused = this.data.focused,
value = this.data.value
} = options;
return this.data.clearable && focused && value !== '' && !this.data.readonly; return (
this.data.clearable && focused && value !== '' && !this.data.readonly
);
}, },
onClear() { onClear() {
@ -111,12 +105,12 @@ Component({
value: '', value: '',
showClear: this.getShowClear({ value: '' }) showClear: this.getShowClear({ value: '' })
}); });
this.triggerEvent('input', ''); this.$emit('input', '');
this.triggerEvent('change', ''); this.$emit('change', '');
}, },
onConfirm() { onConfirm() {
this.triggerEvent('confirm', this.data.value); this.$emit('confirm', this.data.value);
} }
} }
}); });

View File

@ -1,11 +1,7 @@
Component({ import { create } from '../common/create';
options: {
addGlobalClass: true
},
externalClasses: ['custom-class'], create({
props: {
properties: {
info: null, info: null,
name: String, name: String,
size: String, size: String,
@ -18,7 +14,7 @@ Component({
methods: { methods: {
onClick() { onClick() {
this.triggerEvent('click'); this.$emit('click');
} }
} }
}); });

View File

@ -1,11 +1,7 @@
Component({ import { create } from '../common/create';
options: {
addGlobalClass: true
},
externalClasses: ['custom-class'], create({
props: {
properties: {
size: { size: {
type: String, type: String,
value: '30px' value: '30px'

View File

@ -1,4 +1,4 @@
export default Behavior({ export const button = Behavior({
properties: { properties: {
loading: Boolean, loading: Boolean,
// 在自定义组件中,无法与外界的 form 组件联动,暂时不开放 // 在自定义组件中,无法与外界的 form 组件联动,暂时不开放
@ -35,23 +35,23 @@ export default Behavior({
methods: { methods: {
bindgetuserinfo(event = {}) { bindgetuserinfo(event = {}) {
this.triggerEvent('getuserinfo', event.detail || {}); this.$emit('getuserinfo', event.detail || {});
}, },
bindcontact(event = {}) { bindcontact(event = {}) {
this.triggerEvent('contact', event.detail || {}); this.$emit('contact', event.detail || {});
}, },
bindgetphonenumber(event = {}) { bindgetphonenumber(event = {}) {
this.triggerEvent('getphonenumber', event.detail || {}); this.$emit('getphonenumber', event.detail || {});
}, },
bindopensetting(event = {}) { bindopensetting(event = {}) {
this.triggerEvent('opensetting', event.detail || {}); this.$emit('opensetting', event.detail || {});
}, },
binderror(event = {}) { binderror(event = {}) {
this.triggerEvent('error', event.detail || {}); this.$emit('error', event.detail || {});
} }
} }
}); });

View File

@ -1,4 +1,4 @@
export default Behavior({ export const touch = Behavior({
methods: { methods: {
touchStart(event) { touchStart(event) {
this.direction = ''; this.direction = '';

View File

@ -1,4 +1,4 @@
export default function(showDefaultValue) { export const transition = function(showDefaultValue) {
return Behavior({ return Behavior({
properties: { properties: {
customStyle: String, customStyle: String,
@ -51,4 +51,4 @@ export default function(showDefaultValue) {
} }
} }
}); });
} };

View File

@ -1,15 +1,9 @@
Component({ import { create } from '../common/create';
externalClasses: [
'custom-class',
'title-class'
],
options: { create({
multipleSlots: true, classes: ['title-class'],
addGlobalClass: true
},
properties: { props: {
title: String, title: String,
leftText: String, leftText: String,
rightText: String, rightText: String,
@ -23,11 +17,11 @@ Component({
methods: { methods: {
onClickLeft() { onClickLeft() {
this.triggerEvent('click-left'); this.$emit('click-left');
}, },
onClickRight() { onClickRight() {
this.triggerEvent('click-right'); this.$emit('click-right');
} }
} }
}); });

View File

@ -1,20 +1,15 @@
const VALID_MODE = ['closeable', 'link']; import { create } from '../common/create';
const FONT_COLOR = '#f60'; const FONT_COLOR = '#f60';
const BG_COLOR = '#fff7cc'; const BG_COLOR = '#fff7cc';
Component({ create({
options: { props: {
addGlobalClass: true
},
externalClasses: ['custom-class'],
properties: {
text: { text: {
type: String, type: String,
value: '', value: '',
observer() { observer() {
this.setData({}, this._init); this.setData({}, this.init);
} }
}, },
mode: { mode: {
@ -67,8 +62,7 @@ Component({
}, },
attached() { attached() {
const { mode } = this.data; if (this.data.mode) {
if (mode && this._checkMode(mode)) {
this.setData({ this.setData({
hasRightIcon: true hasRightIcon: true
}); });
@ -81,15 +75,7 @@ Component({
}, },
methods: { methods: {
_checkMode(val) { init() {
const isValidMode = ~VALID_MODE.indexOf(val);
if (!isValidMode) {
console.warn(`mode only accept value of ${VALID_MODE}, now get ${val}.`);
}
return isValidMode;
},
_init() {
wx.createSelectorQuery() wx.createSelectorQuery()
.in(this) .in(this)
.select('.van-notice-bar__content') .select('.van-notice-bar__content')
@ -132,7 +118,7 @@ Component({
animation, animation,
resetAnimation resetAnimation
}, () => { }, () => {
this._scroll(); this.scroll();
}); });
} }
}) })
@ -141,7 +127,7 @@ Component({
.exec(); .exec();
}, },
_scroll() { scroll() {
const { const {
animation, resetAnimation, wrapWidth, elapse, speed animation, resetAnimation, wrapWidth, elapse, speed
} = this.data; } = this.data;
@ -157,7 +143,7 @@ Component({
}, 100); }, 100);
const timer = setTimeout(() => { const timer = setTimeout(() => {
this._scroll(); this.scroll();
}, elapse); }, elapse);
this.setData({ this.setData({
@ -165,7 +151,7 @@ Component({
}); });
}, },
_handleButtonClick() { onClickIcon() {
const { timer } = this.data; const { timer } = this.data;
timer && clearTimeout(timer); timer && clearTimeout(timer);
this.setData({ this.setData({
@ -175,7 +161,7 @@ Component({
}, },
onClick(event) { onClick(event) {
this.triggerEvent('click', event); this.$emit('click', event);
} }
} }
}); });

View File

@ -18,7 +18,7 @@
wx:if="{{ mode === 'closeable' }}" wx:if="{{ mode === 'closeable' }}"
class="van-notice-bar__right-icon" class="van-notice-bar__right-icon"
name="close" name="close"
bind:tap="_handleButtonClick" bind:tap="onClickIcon"
/> />
<navigator <navigator
wx:if="{{ mode === 'link' }}" wx:if="{{ mode === 'link' }}"

View File

@ -1,11 +1,8 @@
import { create } from '../common/create';
import Notify from './notify'; import Notify from './notify';
Component({ create({
options: { props: {
addGlobalClass: true
},
properties: {
text: String, text: String,
color: { color: {
type: String, type: String,

View File

@ -1,9 +1,7 @@
Component({ import { create } from '../common/create';
options: {
addGlobalClass: true
},
properties: { create({
props: {
show: Boolean, show: Boolean,
mask: Boolean, mask: Boolean,
customStyle: String, customStyle: String,
@ -15,7 +13,7 @@ Component({
methods: { methods: {
onClick() { onClick() {
this.triggerEvent('click'); this.$emit('click');
} }
} }
}); });

View File

@ -1,15 +1,9 @@
Component({ import { create } from '../common/create';
externalClasses: [
'custom-class',
'footer-class'
],
options: { create({
multipleSlots: true, classes: ['footer-class'],
addGlobalClass: true
},
properties: { props: {
desc: String, desc: String,
title: String, title: String,
status: String, status: String,

View File

@ -1,15 +1,10 @@
import transitionBehaviors from '../behaviors/transition'; import { create } from '../common/create';
import { transition } from '../mixins/transition';
Component({ create({
options: { mixins: [transition(false)],
addGlobalClass: true
},
externalClasses: ['custom-class'], props: {
behaviors: [transitionBehaviors(false)],
properties: {
overlayStyle: String, overlayStyle: String,
overlay: { overlay: {
type: Boolean, type: Boolean,
@ -27,10 +22,10 @@ Component({
methods: { methods: {
onClickOverlay() { onClickOverlay() {
this.triggerEvent('click-overlay'); this.$emit('click-overlay');
if (this.data.closeOnClickOverlay) { if (this.data.closeOnClickOverlay) {
this.triggerEvent('close'); this.$emit('close');
} }
} }
} }

View File

@ -1,13 +1,7 @@
Component({ import { create } from '../common/create';
options: {
addGlobalClass: true
},
externalClasses: [ create({
'custom-class' props: {
],
properties: {
inactive: { inactive: {
type: Boolean, type: Boolean,
observer() { observer() {

View File

@ -1,24 +1,16 @@
const COL_PATH = '../col/index'; import { create } from '../common/create';
Component({
options: {
addGlobalClass: true
},
externalClasses: ['custom-class'],
create({
relations: { relations: {
[COL_PATH]: { '../col/index': {
type: 'descendant' type: 'descendant'
} }
}, },
properties: { props: {
gutter: { gutter: {
type: Number, type: Number,
observer() { observer: 'setGutter'
this.setGutter();
}
} }
}, },
@ -33,7 +25,7 @@ Component({
const style = gutter ? `margin-right: ${margin}; margin-left: ${margin};` : ''; const style = gutter ? `margin-right: ${margin}; margin-left: ${margin};` : '';
this.setData({ style }); this.setData({ style });
this.getRelationNodes(COL_PATH).forEach((col) => { this.getRelationNodes('../col/index').forEach((col) => {
col.setGutter(this.data.gutter); col.setGutter(this.data.gutter);
}); });
} }

View File

@ -1,14 +1,11 @@
Component({ import { create } from '../common/create';
behaviors: ['wx://form-field'],
externalClasses: ['custom-class', 'cancel-class'], create({
field: true,
options: { classes: ['cancel-class'],
multipleSlots: true,
addGlobalClass: true
},
properties: { props: {
focus: Boolean, focus: Boolean,
disabled: Boolean, disabled: Boolean,
readonly: Boolean, readonly: Boolean,
@ -27,25 +24,25 @@ Component({
methods: { methods: {
onChange(event) { onChange(event) {
this.triggerEvent('change', event.detail); this.$emit('change', event.detail);
}, },
onCancel() { onCancel() {
this.setData({ value: '' }); this.setData({ value: '' });
this.triggerEvent('cancel'); this.$emit('cancel');
this.triggerEvent('change', ''); this.$emit('change', '');
}, },
onSearch() { onSearch() {
this.triggerEvent('search', this.data.value); this.$emit('search', this.data.value);
}, },
onFocus() { onFocus() {
this.triggerEvent('focus'); this.$emit('focus');
}, },
onBlur() { onBlur() {
this.triggerEvent('blur'); this.$emit('blur');
} }
} }
}); });

View File

@ -1,15 +1,10 @@
import touchBehaviors from '../behaviors/touch'; import { create } from '../common/create';
import { touch } from '../mixins/touch';
Component({ create({
options: { mixins: [touch],
addGlobalClass: true
},
externalClasses: ['custom-class'], props: {
behaviors: [touchBehaviors],
properties: {
disabled: Boolean, disabled: Boolean,
max: { max: {
type: Number, type: Number,
@ -86,7 +81,7 @@ Component({
}); });
if (end) { if (end) {
this.triggerEvent('change', value); this.$emit('change', value);
} }
}, },

View File

@ -1,22 +1,19 @@
import { create } from '../common/create';
// Note that the bitwise operators and shift operators operate on 32-bit ints // Note that the bitwise operators and shift operators operate on 32-bit ints
// so in that case, the max safe integer is 2^31-1, or 2147483647 // so in that case, the max safe integer is 2^31-1, or 2147483647
const MAX = 2147483647; const MAX = 2147483647;
Component({ create({
behaviors: ['wx://form-field'], field: true,
options: { classes: [
addGlobalClass: true
},
externalClasses: [
'custom-class',
'input-class', 'input-class',
'plus-class', 'plus-class',
'minus-class' 'minus-class'
], ],
properties: { props: {
integer: Boolean, integer: Boolean,
disabled: Boolean, disabled: Boolean,
disableInput: Boolean, disableInput: Boolean,
@ -53,20 +50,20 @@ Component({
onChange(type) { onChange(type) {
if (this[`${type}Disabled`]) { if (this[`${type}Disabled`]) {
this.triggerEvent('overlimit', type); this.$emit('overlimit', type);
return; return;
} }
const diff = type === 'minus' ? -this.data.step : +this.data.step; const diff = type === 'minus' ? -this.data.step : +this.data.step;
const value = Math.round((this.data.value + diff) * 100) / 100; const value = Math.round((this.data.value + diff) * 100) / 100;
this.triggerInput(this.range(value)); this.triggerInput(this.range(value));
this.triggerEvent(type); this.$emit(type);
}, },
onBlur(event) { onBlur(event) {
const value = this.range(this.data.value); const value = this.range(this.data.value);
this.triggerInput(value); this.triggerInput(value);
this.triggerEvent('blur', event); this.$emit('blur', event);
}, },
onMinus() { onMinus() {
@ -79,7 +76,7 @@ Component({
triggerInput(value) { triggerInput(value) {
this.setData({ value }); this.setData({ value });
this.triggerEvent('change', value); this.$emit('change', value);
} }
} }
}); });

View File

@ -1,25 +1,15 @@
Component({ import { create } from '../common/create';
options: {
addGlobalClass: true
},
externalClasses: [ create({
'custom-class' props: {
],
properties: {
icon: String, icon: String,
steps: { steps: {
type: Array, type: Array,
observer() { observer: 'formatSteps'
this.formatSteps();
}
}, },
active: { active: {
type: Number, type: Number,
observer() { observer: 'formatSteps'
this.formatSteps();
}
}, },
direction: { direction: {
type: String, type: String,

View File

@ -1,11 +1,9 @@
Component({ import { create } from '../common/create';
behaviors: ['wx://form-field'],
options: { create({
addGlobalClass: true field: true,
},
properties: { props: {
title: String, title: String,
border: Boolean, border: Boolean,
loading: Boolean, loading: Boolean,
@ -28,7 +26,7 @@ Component({
methods: { methods: {
onChange(event) { onChange(event) {
this.triggerEvent('change', event.detail); this.$emit('change', event.detail);
} }
} }
}); });

View File

@ -1,13 +1,11 @@
Component({ import { create } from '../common/create';
behaviors: ['wx://form-field'],
options: { create({
addGlobalClass: true field: true,
},
externalClasses: ['custom-class', 'node-class'], classes: ['node-class'],
properties: { props: {
loading: Boolean, loading: Boolean,
disabled: Boolean, disabled: Boolean,
checked: { checked: {
@ -30,8 +28,8 @@ Component({
onClick() { onClick() {
if (!this.data.disabled && !this.data.loading) { if (!this.data.disabled && !this.data.loading) {
const checked = !this.data.checked; const checked = !this.data.checked;
this.triggerEvent('input', checked); this.$emit('input', checked);
this.triggerEvent('change', checked); this.$emit('change', checked);
} }
} }
} }

View File

@ -1,16 +1,12 @@
const TABS_PATH = '../tabs/index'; import { create } from '../common/create';
Component({ create({
options: { props: {
addGlobalClass: true
},
properties: {
disabled: Boolean, disabled: Boolean,
title: { title: {
type: String, type: String,
observer() { observer() {
const parent = this.getRelationNodes(TABS_PATH)[0]; const parent = this.getRelationNodes('../tabs/index')[0];
if (parent) { if (parent) {
parent.setLine(); parent.setLine();
} }
@ -19,7 +15,7 @@ Component({
}, },
relations: { relations: {
[TABS_PATH]: { '../tabs/index': {
type: 'ancestor' type: 'ancestor'
} }
}, },

View File

@ -1,19 +1,14 @@
const TABBAR_PATH = '../tabbar/index'; import { create } from '../common/create';
Component({ create({
properties: { props: {
info: null, info: null,
icon: String, icon: String,
dot: Boolean dot: Boolean
}, },
options: {
multipleSlots: true,
addGlobalClass: true
},
relations: { relations: {
[TABBAR_PATH]: { '../tabbar/index': {
type: 'ancestor' type: 'ancestor'
} }
}, },
@ -25,11 +20,11 @@ Component({
methods: { methods: {
onClick() { onClick() {
const parent = this.getRelationNodes(TABBAR_PATH)[0]; const parent = this.getRelationNodes('../tabbar/index')[0];
if (parent) { if (parent) {
parent.onChange(this); parent.onChange(this);
} }
this.triggerEvent('click'); this.$emit('click');
} }
} }
}); });

View File

@ -1,13 +1,7 @@
const ITEM_PATH = '../tabbar-item/index'; import { create } from '../common/create';
Component({ create({
options: { props: {
addGlobalClass: true
},
externalClasses: ['custom-class'],
properties: {
active: { active: {
type: Number, type: Number,
observer(active) { observer(active) {
@ -35,7 +29,7 @@ Component({
}, },
relations: { relations: {
[ITEM_PATH]: { '../tabbar-item/index': {
type: 'descendant', type: 'descendant',
linked(target) { linked(target) {
@ -63,7 +57,7 @@ Component({
onChange(child) { onChange(child) {
const active = this.data.items.indexOf(child); const active = this.data.items.indexOf(child);
if (active !== this.data.currentActive && active !== -1) { if (active !== this.data.currentActive && active !== -1) {
this.triggerEvent('change', active); this.$emit('change', active);
this.setData({ currentActive: active }); this.setData({ currentActive: active });
this.setActiveItem(); this.setActiveItem();
} }

View File

@ -1,12 +1,8 @@
const TAB_PATH = '../tab/index'; import { create } from '../common/create';
Component({
options: {
addGlobalClass: true
},
create({
relations: { relations: {
[TAB_PATH]: { '../tab/index': {
type: 'descendant', type: 'descendant',
linked(target) { linked(target) {
@ -33,7 +29,7 @@ Component({
} }
}, },
properties: { props: {
color: { color: {
type: String, type: String,
observer: 'setLine' observer: 'setLine'
@ -78,7 +74,7 @@ Component({
methods: { methods: {
trigger(eventName, index) { trigger(eventName, index) {
this.triggerEvent(eventName, { this.$emit(eventName, {
index, index,
title: this.data.tabs[index].data.title title: this.data.tabs[index].data.title
}); });

View File

@ -1,11 +1,7 @@
Component({ import { create } from '../common/create';
options: {
addGlobalClass: true
},
externalClasses: ['custom-class'], create({
props: {
properties: {
type: String, type: String,
mark: Boolean, mark: Boolean,
plain: Boolean plain: Boolean

View File

@ -1,11 +1,8 @@
import { create } from '../common/create';
import Toast from './toast'; import Toast from './toast';
Component({ create({
options: { props: {
addGlobalClass: true
},
properties: {
show: Boolean, show: Boolean,
mask: Boolean, mask: Boolean,
message: String, message: String,

View File

@ -1,4 +1,4 @@
import { isObj } from '../utils/index'; import { isObj } from '../common/utils';
const defaultOptions = { const defaultOptions = {
type: 'text', type: 'text',

View File

@ -1,15 +1,10 @@
import transitionBehaviors from '../behaviors/transition'; import { create } from '../common/create';
import { transition } from '../mixins/transition';
Component({ create({
options: { mixins: [transition(true)],
addGlobalClass: true
},
externalClasses: ['custom-class'], props: {
behaviors: [transitionBehaviors(true)],
properties: {
name: { name: {
type: String, type: String,
value: 'fade' value: 'fade'

View File

@ -1,11 +1,9 @@
import { create } from '../common/create';
const ITEM_HEIGHT = 44; const ITEM_HEIGHT = 44;
Component({ create({
options: { props: {
addGlobalClass: true
},
properties: {
items: { items: {
type: Array, type: Array,
observer() { observer() {
@ -16,9 +14,7 @@ Component({
mainActiveIndex: { mainActiveIndex: {
type: Number, type: Number,
value: 0, value: 0,
observer() { observer: 'updateSubItems'
this.updateSubItems();
}
}, },
activeId: { activeId: {
type: Number, type: Number,
@ -46,7 +42,7 @@ Component({
const { const {
dataset = {} dataset = {}
} = event.currentTarget || {}; } = event.currentTarget || {};
this.triggerEvent('click-item', { ...(dataset.item || {}) }); this.$emit('click-item', { ...(dataset.item || {}) });
}, },
// 当一个导航被点击时 // 当一个导航被点击时
@ -54,7 +50,7 @@ Component({
const { const {
dataset = {} dataset = {}
} = event.currentTarget || {}; } = event.currentTarget || {};
this.triggerEvent('click-nav', { index: dataset.index }); this.$emit('click-nav', { index: dataset.index });
}, },
// 更新子项列表 // 更新子项列表

View File

@ -1,4 +1,4 @@
@import "../common/index.pcss"; @import '../common/style/var.pcss';
@import '../common/style/ellipsis.pcss'; @import '../common/style/ellipsis.pcss';
.tree-select { .tree-select {