123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204 |
- import lifecycle from '/util/lifecycle';
- import animModal from '/util/items';
- Page({
- ...lifecycle,
- ...animModal.animOp,
- data: {
- ...animModal.data,
- pageName: 'component/index',
- pageInfo: {
- pageId: 0,
- },
- hidden: true,
- curIndex: 0,
- arr: {
- onItemTap: 'onGridItemTap',
- onChildItemTap: 'onChildItemTap',
- list: [
- {
- icon: '/image/view.png',
- title: '视图容器',
- entitle: 'View',
- subs: [
- {
- title: '基础视图',
- entitle: 'View',
- page: 'view',
- },
- {
- title: '滚动视图',
- entitle: 'ScrollView',
- page: 'scroll-view',
- },
- {
- title: '滑动视图',
- entitle: 'Swiper',
- page: 'swiper',
- },
- ],
- }, {
- icon: '/image/basic.png',
- title: '基础内容',
- entitle: 'Basic Content',
- subs: [
- {
- title: '文字',
- entitle: 'Text',
- page: 'text',
- },
- {
- title: '图标',
- entitle: 'Icon',
- page: 'icon',
- },
- {
- title: '进度条',
- entitle: 'Progress',
- page: 'progress',
- },
- ],
- }, {
- icon: '/image/form.png',
- title: '表单组件',
- entitle: 'Form',
- subs: [
- {
- title: '按钮',
- entitle: 'Button',
- page: 'button',
- },
- {
- title: '复选框',
- entitle: 'Checkbox',
- page: 'checkbox',
- },
- {
- title: '表单',
- entitle: 'Form',
- page: 'form',
- },
- {
- title: '文本输入',
- entitle: 'Input',
- page: 'input',
- },
- {
- title: '标签',
- entitle: 'Label',
- page: 'label',
- },
- {
- title: '选择器视图',
- entitle: 'PickerView',
- page: 'picker-view',
- },
- {
- title: '选择器',
- entitle: 'Picker',
- page: 'picker',
- },
- {
- title: '单选框',
- entitle: 'Radio',
- page: 'radio',
- },
- {
- title: '滑动条',
- entitle: 'Slider',
- page: 'slider',
- },
- {
- title: '开关',
- entitle: 'Switch',
- page: 'switch',
- },
- {
- title: '多行输入',
- entitle: 'Textarea',
- page: 'textarea',
- },
- ],
- }, {
- icon: '/image/feedback.png',
- title: '操作反馈',
- entitle: 'Feedback',
- subs: [
- {
- title: '动作面板',
- entitle: 'ActionSheet',
- page: 'action-sheet',
- },
- {
- title: '对话框',
- entitle: 'Modal',
- page: 'modal',
- },
- {
- title: '轻提示',
- entitle: 'Toast',
- page: 'toast',
- },
- {
- title: '加载提示',
- entitle: 'Loading',
- page: 'loading',
- },
- ],
- }, {
- icon: '/image/navigator.png',
- title: '导航',
- entitle: 'Navigator',
- page: 'navigator',
- }, {
- icon: '/image/media.png',
- title: '媒体组件',
- entitle: 'Media',page: 'image',
- }, {
- icon: '/image/map.png',
- title: '地图',
- entitle: 'Map',
- page: 'map',
- }, {
- icon: '/image/canvas.png',
- title: '画布',
- entitle: 'Canvas',
- page: 'canvas',
- },
- ],
- },
- },
- onGridItemTap(e) {
- const curIndex = e.target.dataset.index;
- const childList = this.data.arr.list[curIndex];
- if (childList.subs) {
- this.setData({
- hidden: !this.data.hidden,
- curIndex,
- });
- this.createMaskShowAnim();
- this.createContentShowAnim();
- } else {
- this.onChildItemTap({
- target: {
- dataset: { page: childList.page },
- },
- });
- }
- },
- onChildItemTap(e) {
- const { page } = e.target.dataset;
- my.navigateTo({
- url: `component-pages/${page}/${page}`,
- });
- },
- onModalCloseTap() {
- this.createMaskHideAnim();
- this.createContentHideAnim();
- setTimeout(() => {
- this.setData({
- hidden: true,
- });
- }, 210);
- },
- });
|