├── .env.development
├── .env.production
├── .github
└── workflows
│ └── ci.yml
├── .gitignore
├── LICENSE
├── README.md
├── lerna.json
├── miniprogram
├── app.json
├── app.less
├── app.ts
├── components
│ ├── ActionSheet
│ │ ├── index.json
│ │ ├── index.less
│ │ ├── index.ts
│ │ ├── index.wxml
│ │ ├── package.json
│ │ └── readme.md
│ ├── Button
│ │ ├── index.json
│ │ ├── index.less
│ │ ├── index.ts
│ │ ├── index.wxml
│ │ ├── index.wxs
│ │ ├── package.json
│ │ └── readme.md
│ ├── Card
│ │ ├── index.json
│ │ ├── index.less
│ │ ├── index.ts
│ │ ├── index.wxml
│ │ ├── index.wxs
│ │ ├── package.json
│ │ └── readme.md
│ ├── Dialog
│ │ ├── index.json
│ │ ├── index.less
│ │ ├── index.ts
│ │ ├── index.wxml
│ │ ├── package.json
│ │ └── readme.md
│ ├── DialogQueue
│ │ ├── index.json
│ │ ├── index.less
│ │ ├── index.ts
│ │ ├── index.wxml
│ │ ├── package.json
│ │ └── readme.md
│ ├── Icon
│ │ ├── data.ts
│ │ ├── index.json
│ │ ├── index.less
│ │ ├── index.ts
│ │ ├── index.wxml
│ │ ├── index.wxs
│ │ ├── package.json
│ │ ├── readme.md
│ │ └── rest
│ │ │ └── icon_types.ts
│ ├── Landing
│ │ ├── index.json
│ │ ├── index.less
│ │ ├── index.ts
│ │ ├── index.wxml
│ │ ├── package.json
│ │ └── readme.md
│ ├── Line
│ │ ├── index.json
│ │ ├── index.less
│ │ ├── index.ts
│ │ ├── index.wxml
│ │ ├── index.wxs
│ │ ├── package.json
│ │ └── readme.md
│ ├── Loading
│ │ ├── index.json
│ │ ├── index.less
│ │ ├── index.ts
│ │ ├── index.wxml
│ │ ├── package.json
│ │ ├── readme.md
│ │ └── style
│ │ │ ├── loading.less
│ │ │ ├── loading.wxss
│ │ │ ├── refresh.less
│ │ │ └── refresh.wxss
│ ├── Modal
│ │ ├── index.json
│ │ ├── index.less
│ │ ├── index.ts
│ │ ├── index.wxml
│ │ ├── package.json
│ │ └── readme.md
│ ├── NoticeBar
│ │ ├── index.json
│ │ ├── index.less
│ │ ├── index.ts
│ │ ├── index.wxml
│ │ ├── index.wxs
│ │ ├── package.json
│ │ ├── readme.md
│ │ └── rest
│ │ │ └── icons.ts
│ ├── Period
│ │ ├── index.json
│ │ ├── index.less
│ │ ├── index.ts
│ │ ├── index.wxml
│ │ ├── package.json
│ │ └── readme.md
│ ├── Popover
│ │ ├── index.json
│ │ ├── index.less
│ │ ├── index.ts
│ │ ├── index.wxml
│ │ ├── index.wxs
│ │ ├── package.json
│ │ └── readme.md
│ ├── Ripple
│ │ ├── index.json
│ │ ├── index.less
│ │ ├── index.ts
│ │ ├── index.wxml
│ │ ├── package.json
│ │ └── readme.md
│ ├── SnackBar
│ │ ├── index.json
│ │ ├── index.less
│ │ ├── index.ts
│ │ ├── index.wxml
│ │ ├── index.wxs
│ │ ├── package.json
│ │ └── readme.md
│ ├── Sticky
│ │ ├── index.json
│ │ ├── index.less
│ │ ├── index.ts
│ │ ├── index.wxml
│ │ ├── index.wxs
│ │ ├── package.json
│ │ └── readme.md
│ ├── Tab
│ │ ├── Sticky
│ │ │ ├── index.json
│ │ │ ├── index.less
│ │ │ ├── index.ts
│ │ │ ├── index.wxml
│ │ │ └── index.wxs
│ │ ├── TabItem
│ │ │ ├── index.json
│ │ │ ├── index.less
│ │ │ ├── index.ts
│ │ │ └── index.wxml
│ │ ├── behavior.ts
│ │ ├── index.json
│ │ ├── index.less
│ │ ├── index.ts
│ │ ├── index.wxml
│ │ ├── index.wxs
│ │ ├── package.json
│ │ └── readme.md
│ ├── Text
│ │ ├── index.json
│ │ ├── index.less
│ │ ├── index.ts
│ │ ├── index.wxml
│ │ ├── index.wxs
│ │ ├── package.json
│ │ └── readme.md
│ └── Toast
│ │ ├── index.json
│ │ ├── index.less
│ │ ├── index.ts
│ │ ├── index.wxml
│ │ ├── package.json
│ │ └── readme.md
├── data
│ └── menu_items.ts
├── image
│ ├── icon_add_person.svg
│ ├── icon_add_person_black.svg
│ ├── icon_chat.svg
│ ├── icon_chat_black.svg
│ ├── icon_close.svg
│ ├── icon_feedback.svg
│ ├── icon_feedback_black.svg
│ ├── icon_info.svg
│ ├── icon_pay.svg
│ ├── icon_pay_black.svg
│ ├── icon_right.svg
│ ├── icon_scan.svg
│ ├── icon_scan_black.svg
│ ├── logo_dingding.svg
│ ├── logo_instagram.svg
│ ├── logo_pengyouquan.svg
│ ├── logo_qq.svg
│ ├── logo_qzone.svg
│ ├── logo_wechat.svg
│ ├── logo_weibo.svg
│ ├── logo_yixin.svg
│ └── logo_zhihu.svg
├── page_components
│ └── _Tips
│ │ ├── index.json
│ │ ├── index.less
│ │ ├── index.ts
│ │ └── index.wxml
├── pages
│ ├── ActionSheet
│ │ ├── index.json
│ │ ├── index.less
│ │ ├── index.ts
│ │ └── index.wxml
│ ├── Button
│ │ ├── index.json
│ │ ├── index.less
│ │ ├── index.ts
│ │ └── index.wxml
│ ├── Card
│ │ ├── index.json
│ │ ├── index.less
│ │ ├── index.ts
│ │ └── index.wxml
│ ├── Dialog
│ │ ├── index.json
│ │ ├── index.less
│ │ ├── index.ts
│ │ └── index.wxml
│ ├── DialogQueue
│ │ ├── index.json
│ │ ├── index.less
│ │ ├── index.ts
│ │ └── index.wxml
│ ├── Icon
│ │ ├── index.json
│ │ ├── index.less
│ │ ├── index.ts
│ │ └── index.wxml
│ ├── Landing
│ │ ├── index.json
│ │ ├── index.less
│ │ ├── index.ts
│ │ └── index.wxml
│ ├── Line
│ │ ├── index.json
│ │ ├── index.less
│ │ ├── index.ts
│ │ └── index.wxml
│ ├── Loading
│ │ ├── index.json
│ │ ├── index.less
│ │ ├── index.ts
│ │ └── index.wxml
│ ├── Modal
│ │ ├── index.json
│ │ ├── index.less
│ │ ├── index.ts
│ │ └── index.wxml
│ ├── NoticeBar
│ │ ├── index.json
│ │ ├── index.less
│ │ ├── index.ts
│ │ └── index.wxml
│ ├── Period
│ │ ├── index.json
│ │ ├── index.less
│ │ ├── index.ts
│ │ └── index.wxml
│ ├── Popover
│ │ ├── index.json
│ │ ├── index.less
│ │ ├── index.ts
│ │ └── index.wxml
│ ├── Ripple
│ │ ├── index.json
│ │ ├── index.less
│ │ ├── index.ts
│ │ └── index.wxml
│ ├── SnackBar
│ │ ├── index.json
│ │ ├── index.less
│ │ ├── index.ts
│ │ └── index.wxml
│ ├── Sticky
│ │ ├── index.json
│ │ ├── index.less
│ │ ├── index.ts
│ │ └── index.wxml
│ ├── Tab
│ │ ├── index.json
│ │ ├── index.less
│ │ ├── index.ts
│ │ └── index.wxml
│ ├── Text
│ │ ├── index.json
│ │ ├── index.less
│ │ ├── index.ts
│ │ └── index.wxml
│ ├── Toast
│ │ ├── index.json
│ │ ├── index.less
│ │ ├── index.ts
│ │ └── index.wxml
│ └── index
│ │ ├── index.json
│ │ ├── index.less
│ │ ├── index.ts
│ │ └── index.wxml
├── sitemap.json
├── styles
│ ├── atom-miniapp.min.wxss
│ ├── init.less
│ └── vars.less
└── utils
│ ├── util.js
│ └── util.ts
├── package.json
├── project.config.json
├── tsconfig.json
├── typings
└── index.d.ts
├── webpack
├── es5
│ ├── build.js
│ ├── compile.tsconfig.json
│ ├── loaders.js
│ ├── plugins.js
│ └── webpack.config.js
├── loaders.js
├── plugins.js
├── resolve.js
├── utils.js
├── webpack.config.common.js
├── webpack.config.dev.js
└── webpack.config.prod.js
└── yarn.lock
/.env.development:
--------------------------------------------------------------------------------
1 | MODE='dev'
--------------------------------------------------------------------------------
/.env.production:
--------------------------------------------------------------------------------
1 | MODE='prod'
--------------------------------------------------------------------------------
/.github/workflows/ci.yml:
--------------------------------------------------------------------------------
1 | name: Deploy Actions
2 |
3 | on:
4 | push:
5 | branches:
6 | - master
7 | paths-ignore:
8 | - test
9 | - README.md
10 | - LICENSE
11 |
12 | jobs:
13 | Deploy:
14 | runs-on: ubuntu-20.04
15 | steps:
16 | - name: Checkout Repo
17 | uses: actions/checkout@v2
18 |
19 | - name: Start Service
20 | uses: appleboy/ssh-action@master
21 | with:
22 | port: '22'
23 | host: ${{ secrets.SSH_HOST }}
24 | username: ${{ secrets.SSH_USERNAME }}
25 | key: ${{ secrets.DEPLOY_KEY }}
26 | script: cd /App/light-design-server/ && npm run update:submodule && npm run d:prod && docker system prune -af
--------------------------------------------------------------------------------
/.gitignore:
--------------------------------------------------------------------------------
1 | # See https://help.github.com/articles/ignoring-files/ for more about ignoring files.
2 |
3 | # dependencies
4 | */node_modules
5 | /.pnp
6 | .pnp.js
7 |
8 | # testing
9 | /coverage
10 |
11 | # production
12 | /miniprogram/pages_components/*.js
13 | /miniprogram/pages_components/*.wxss
14 | /miniprogram/components/*.js
15 | /miniprogram/components/*.wxss
16 | /miniprogram/pages/*.js
17 | /miniprogram/pages/*.wxss
18 | /dist
19 | /build
20 | /miniprogram/components_es5
21 | *.zip
22 | *.lock
23 | project.private.config.json
24 |
25 | # env
26 | .DS_Store
27 | .env.local
28 | .env.development.local
29 | .env.test.local
30 | .env.production.local
31 |
32 | # log
33 | *-debug.log*
34 | node_modules
35 |
--------------------------------------------------------------------------------
/LICENSE:
--------------------------------------------------------------------------------
1 | MIT License
2 |
3 | Copyright (c) 2019 Dark
4 |
5 | Permission is hereby granted, free of charge, to any person obtaining a copy
6 | of this software and associated documentation files (the "Software"), to deal
7 | in the Software without restriction, including without limitation the rights
8 | to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
9 | copies of the Software, and to permit persons to whom the Software is
10 | furnished to do so, subject to the following conditions:
11 |
12 | The above copyright notice and this permission notice shall be included in all
13 | copies or substantial portions of the Software.
14 |
15 | THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16 | IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17 | FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
18 | AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
19 | LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
20 | OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
21 | SOFTWARE.
22 |
--------------------------------------------------------------------------------
/README.md:
--------------------------------------------------------------------------------
1 |

2 |
3 | # Light Design
4 |
5 | _[lightd.matrixages.com](https://lightd.matrixages.com/)
_
6 |
7 | _可能是世界上最漂亮的微信小程序组件库
_
8 |
9 |
10 |
11 |
12 |
13 |
14 |
15 |
16 |
17 |
18 | ### Light Design Rules
19 |
20 | - 自然的(natural)
21 | - 原子化(atomic)
22 | - 环保(economical)
23 | - 贴近现实(reality)
24 | - 友好的
25 | - 人格化(personality)
26 | - 符合习惯(conventional)
27 | - 尊重人的(respectful)
28 | - 美的
29 | - 富有创意(creative)
30 | - 简约的(zen)
31 | - 风格化(stylized)
32 |
33 | 
34 |
35 | ### Dev Route
36 |
37 | - Demo site made by Vuejs.
38 | - The number of components increased to 36+.
39 | - Components of React version.
40 | - Unit test for all components.
41 | - DSL of components which transforming a miniprogram component to Web Component / Vue Component / React Component
42 |
43 |
--------------------------------------------------------------------------------
/lerna.json:
--------------------------------------------------------------------------------
1 | {
2 | "packages": [
3 | "miniprogram/components/*"
4 | ],
5 | "version": "independent",
6 | "npmClient": "yarn",
7 | "useWorkspaces": true,
8 | "command": {
9 | "publish": {
10 | "ignoreChanges": [
11 | "ignored-file"
12 | ]
13 | },
14 | "bootstrap": {
15 | "npmClientArgs": [
16 | "--no-package-lock"
17 | ]
18 | }
19 | }
20 | }
--------------------------------------------------------------------------------
/miniprogram/app.json:
--------------------------------------------------------------------------------
1 | {
2 | "pages": [
3 | "pages/index/index",
4 | "pages/Button/index",
5 | "pages/ActionSheet/index",
6 | "pages/Card/index",
7 | "pages/Dialog/index",
8 | "pages/DialogQueue/index",
9 | "pages/Landing/index",
10 | "pages/Loading/index",
11 | "pages/Modal/index",
12 | "pages/SnackBar/index",
13 | "pages/Ripple/index",
14 | "pages/Line/index",
15 | "pages/Toast/index",
16 | "pages/Popover/index",
17 | "pages/Sticky/index",
18 | "pages/Text/index",
19 | "pages/Icon/index",
20 | "pages/NoticeBar/index",
21 | "pages/Period/index",
22 | "pages/Tab/index"
23 | ],
24 | "window": {
25 | "backgroundTextStyle": "light",
26 | "navigationBarBackgroundColor": "#fff",
27 | "navigationBarTitleText": "Light Design",
28 | "navigationBarTextStyle": "black"
29 | },
30 | "style": "v2",
31 | "sitemapLocation": "sitemap.json",
32 | "usingComponents": {
33 | "light-button": "components/Button/index",
34 | "light-action-sheet": "components/ActionSheet/index",
35 | "light-card": "components/Card/index",
36 | "light-dialog": "components/Dialog/index",
37 | "light-dialog-queue": "components/DialogQueue/index",
38 | "light-landing": "components/Landing/index",
39 | "light-loading": "components/Loading/index",
40 | "light-modal": "components/Modal/index",
41 | "light-snack-bar": "components/SnackBar/index",
42 | "light-ripple": "components/Ripple/index",
43 | "light-line": "components/Line/index",
44 | "light-toast": "components/Toast/index",
45 | "light-popover": "components/Popover/index",
46 | "light-sticky": "components/Sticky/index",
47 | "light-text": "components/Text/index",
48 | "light-icon": "components/Icon/index",
49 | "light-notice-bar": "components/NoticeBar/index",
50 | "light-period": "components/Period/index",
51 | "light-tab": "components/Tab/index",
52 | "light-tab-item": "components/Tab/TabItem/index",
53 | "tips": "page_components/_Tips/index"
54 | }
55 | }
--------------------------------------------------------------------------------
/miniprogram/app.less:
--------------------------------------------------------------------------------
1 | @import './styles/atom-miniapp.min.wxss';
2 | @import './styles/init.less';
3 | @import './styles/vars.less';
4 |
5 | page {
6 | background-color: var(--color_background);
7 | overflow-x: hidden;
8 | text-align: left;
9 | }
10 |
11 | .mini_items {
12 | display: flex;
13 | flex-direction: row;
14 | flex-wrap: wrap;
15 | border-top: 2rpx solid var(--color_border);
16 |
17 | &.no_border {
18 | border-top: none;
19 | }
20 |
21 | &.column_2 {
22 | .example_item {
23 | width: 100%/2;
24 |
25 | &:nth-of-type(2n) {
26 | border-right: none;
27 | }
28 |
29 | &:nth-of-type(3n) {
30 | border-right: 2rpx solid var(--color_border);
31 | }
32 |
33 | .examples {
34 | flex-direction: column;
35 |
36 | .example {
37 | align-items: center;
38 | }
39 | }
40 | }
41 | }
42 |
43 | &.visible_items {
44 | .example_item {
45 | flex-direction: row;
46 | justify-content: space-between;
47 | align-items: center;
48 |
49 | .title_wrap {
50 | margin-bottom: 0;
51 | }
52 | }
53 | }
54 |
55 | .example_item {
56 | width: 100%/3;
57 | padding: 60rpx 48rpx;
58 | border-right: 2rpx solid var(--color_border);
59 |
60 | &:nth-of-type(3n) {
61 | border-right: none;
62 | }
63 |
64 | &:last-child {
65 | border-bottom: 2rpx solid var(--color_border);
66 | }
67 |
68 | .title_wrap {
69 | flex-direction: column;
70 |
71 | .title {
72 | font-size: 24rpx;
73 | margin-bottom: 12rpx;
74 | }
75 | }
76 |
77 | .examples {
78 | height: 100%;
79 |
80 | .example {
81 | padding: 12rpx 0;
82 | }
83 | }
84 | }
85 | }
86 |
87 | .example_items {
88 | padding: 0;
89 | padding-bottom: calc(~'0px + 'env(safe-area-inset-bottom));
90 |
91 | &.mini_items {
92 | .mini_items();
93 | }
94 |
95 | .example_item {
96 | flex-direction: column;
97 | padding: 60rpx;
98 | background-color: var(--color_background);
99 | border-bottom: 2rpx solid var(--color_border);
100 | transition: all ease 0.3s;
101 |
102 | &:last-child {
103 | border-bottom: none;
104 | }
105 |
106 | .title_wrap {
107 | flex-direction: row;
108 | justify-content: space-between;
109 | width: 100%;
110 | margin-bottom: 36rpx;
111 |
112 | .title {
113 | font-weight: 500;
114 | line-height: 1;
115 | }
116 |
117 | .attr {
118 | font-size: 26rpx;
119 | line-height: 1;
120 | color: var(--color_text_desc);
121 | }
122 | }
123 |
124 | .examples {
125 | width: 100%;
126 | box-sizing: border-box;
127 | }
128 | }
129 |
130 | .mini_items {
131 | .mini_items();
132 | }
133 | }
--------------------------------------------------------------------------------
/miniprogram/app.ts:
--------------------------------------------------------------------------------
1 | App({
2 | globalData: {},
3 | onLaunch () {}
4 | })
5 |
--------------------------------------------------------------------------------
/miniprogram/components/ActionSheet/index.json:
--------------------------------------------------------------------------------
1 | {
2 | "component": true,
3 | "usingComponents": {}
4 | }
--------------------------------------------------------------------------------
/miniprogram/components/ActionSheet/package.json:
--------------------------------------------------------------------------------
1 | {
2 | "name": "@lightd/actionsheet",
3 | "cname":"抽屉",
4 | "version": "1.0.0",
5 | "main": "index.js",
6 | "homepage": "https://github.com/MatrixAges/light-design/tree/master/miniprogram/components/ActionSheet",
7 | "author": "Matrixage",
8 | "license": "MIT"
9 | }
--------------------------------------------------------------------------------
/miniprogram/components/Button/index.json:
--------------------------------------------------------------------------------
1 | {
2 | "component": true
3 | }
--------------------------------------------------------------------------------
/miniprogram/components/Button/index.ts:
--------------------------------------------------------------------------------
1 | Component( {
2 | options: {
3 | multipleSlots: true
4 | },
5 | properties: {
6 | type: {
7 | type: String,
8 | value: 'default'
9 | } as {
10 | type: StringConstructor
11 | value:
12 | | 'default'
13 | | 'primary'
14 | | 'border'
15 | | 'dashed'
16 | | 'warning'
17 | | 'success'
18 | | 'error'
19 | },
20 | size: {
21 | type: String,
22 | value: 'normal'
23 | } as {
24 | type: StringConstructor
25 | value: 'normal' | 'small' | 'large'
26 | },
27 | shape: {
28 | type: String,
29 | value: 'normal'
30 | } as {
31 | type: StringConstructor
32 | value: 'normal' | 'circle' | 'rect'
33 | },
34 | autoWidth: {
35 | type: Boolean,
36 | value: false
37 | },
38 | width: {
39 | type: String,
40 | value: ''
41 | },
42 | height: {
43 | type: String,
44 | value: ''
45 | },
46 | color: {
47 | type: String,
48 | value: ''
49 | },
50 | bgColor: {
51 | type: String,
52 | value: ''
53 | },
54 | iconPath: {
55 | type: String,
56 | value: ''
57 | },
58 | ghost: Boolean,
59 | disabled: Boolean,
60 | loading: Boolean
61 | }
62 | } )
63 |
--------------------------------------------------------------------------------
/miniprogram/components/Button/index.wxml:
--------------------------------------------------------------------------------
1 |
5 |
6 |
--------------------------------------------------------------------------------
/miniprogram/components/Button/index.wxs:
--------------------------------------------------------------------------------
1 | function getClasses( props ) {
2 | var classes = ''
3 |
4 | if ( !props.autoWidth ) classes += ' mode_fixed'
5 | if ( props.autoWidth ) classes += ' mode_padding'
6 | if ( props.size ) classes += ' size_' + props.size
7 | if ( props.type ) classes += ' type_' + props.type
8 | if ( props.shape ) classes += ' shape_' + props.shape
9 | if ( props.ghost ) classes += ' ghost'
10 | if ( props.disabled ) classes += ' disabled'
11 |
12 | return classes
13 | }
14 |
15 | function getStyles( props ) {
16 | var styles = ''
17 |
18 | if ( props.width ) styles += ';width:' + props.width
19 | if ( props.height ) styles += ';height:' + props.height
20 | if ( props.color ) styles += ';color:' + props.color
21 | if ( props.bgColor ) styles += ';background:' + props.bgColor
22 |
23 | return styles
24 | }
25 |
26 | module.exports = {
27 | getClasses: getClasses,
28 | getStyles: getStyles
29 | }
--------------------------------------------------------------------------------
/miniprogram/components/Button/package.json:
--------------------------------------------------------------------------------
1 | {
2 | "name": "@lightd/button",
3 | "cname":"按钮",
4 | "version": "1.0.0",
5 | "main": "index.js",
6 | "homepage": "https://github.com/MatrixAges/light-design/tree/master/miniprogram/components/Button",
7 | "author": "Matrixage",
8 | "license": "MIT"
9 | }
--------------------------------------------------------------------------------
/miniprogram/components/Card/index.json:
--------------------------------------------------------------------------------
1 | {
2 | "component": true,
3 | "usingComponents": {}
4 | }
--------------------------------------------------------------------------------
/miniprogram/components/Card/index.less:
--------------------------------------------------------------------------------
1 | .init {
2 | color: black;
3 | font-size: 30rpx;
4 | line-height: 1.6;
5 | }
6 |
7 | .card_wrap {
8 | display: flex;
9 | overflow: hidden;
10 | box-sizing: border-box;
11 | width: 100%;
12 | border-radius: 0;
13 | background-color: white;
14 | transition: all ease 0.3s;
15 |
16 | .init();
17 |
18 | &.bordered {
19 | border: 2rpx solid rgba(245, 245, 245, 0.72);
20 | }
21 |
22 | &.shadow {
23 | box-shadow: 0 0 30rpx rgba(238, 238, 238, 1);
24 | }
25 |
26 | .card {
27 | display: flex;
28 | flex-direction: column;
29 | width: 100%;
30 | }
31 | }
--------------------------------------------------------------------------------
/miniprogram/components/Card/index.ts:
--------------------------------------------------------------------------------
1 | Component( {
2 | options: {
3 | multipleSlots: true
4 | },
5 | properties: {
6 | width: String,
7 | padding: String,
8 | margin: String,
9 | radius: Number,
10 | fontSize: Number,
11 | color: String,
12 | bgColor: String,
13 | textAlign: String,
14 | bordered: Boolean,
15 | shadow: Boolean,
16 | style: String
17 | }
18 | } )
19 |
--------------------------------------------------------------------------------
/miniprogram/components/Card/index.wxml:
--------------------------------------------------------------------------------
1 |
5 |
6 |
10 |
11 |
12 |
13 |
--------------------------------------------------------------------------------
/miniprogram/components/Card/index.wxs:
--------------------------------------------------------------------------------
1 | function getClasses( props ) {
2 | var classes = ''
3 |
4 | if ( props.bordered ) classes += ' bordered'
5 | if ( props.shadow ) classes += ' shadow'
6 |
7 | return classes
8 | }
9 |
10 | function getStyles( props ) {
11 | var styles = ''
12 |
13 | if ( props.width ) styles += ';width:' + props.width
14 | if ( props.padding ) styles += ';padding:' + props.padding
15 | if ( props.margin ) styles += ';margin:' + props.margin
16 | if ( props.radius ) styles += ';border-radius:' + props.radius + 'rpx'
17 | if ( props.fontSize ) styles += ';font-size:' + props.fontSize + 'rpx'
18 | if ( props.color ) styles += ';color:' + props.color
19 | if ( props.bgColor ) styles += ';background:' + props.bgColor
20 | if ( props.textAlign ) styles += ';text-align:' + props.textAlign
21 |
22 | return styles
23 | }
24 |
25 | module.exports = {
26 | getClasses: getClasses,
27 | getStyles: getStyles
28 | }
--------------------------------------------------------------------------------
/miniprogram/components/Card/package.json:
--------------------------------------------------------------------------------
1 | {
2 | "name": "@lightd/card",
3 | "cname":"卡片",
4 | "version": "1.0.0",
5 | "main": "index.js",
6 | "homepage": "https://github.com/MatrixAges/light-design/tree/master/miniprogram/components/Card",
7 | "author": "Matrixage",
8 | "license": "MIT"
9 | }
--------------------------------------------------------------------------------
/miniprogram/components/Card/readme.md:
--------------------------------------------------------------------------------
1 |
2 |
3 | 卡片是UI的一个标准部分,她是获取更详细信息的入口点。卡片可以是一个单独的组件,但通常由一些标题、副标题和内容组成。
4 |
5 | 使用场景
6 |
7 | - 展示数据项格式一致的列表内容。
8 | - 提供块状的可交互的信息展示面板。
9 | - 区分其他内容进行,提升内容的辨识度。
10 |
11 |
12 |
13 | | 属性 | 说明 | 类型 | 默认值 | 必填 | 版本 |
14 | | - | - | - | - | - | - |
15 | | width | 宽度 | string | '100%' | 否 | 1.0.0 |
16 | | padding | 内边距 | string | '' | 否 | 1.0.0 |
17 | | margin | 外边距 | string | '' | 否 | 1.0.0 |
18 | | radius | 圆角 | number | 0 | 否 | 1.0.0 |
19 | | fontSize | 文字排版 | number | 30 | 否 | 1.0.0 |
20 | | color | 字体颜色 | string | 'black' | 否 | 1.0.0 |
21 | | bgColor | 背景颜色 | string | '' | 否 | 1.0.0 |
22 | | textAlign | 文字排版 | string | '' | 否 | 1.0.0 |
23 | | bordered | 边框 | boolean | false | 否 | 1.0.0 |
24 | | shadow | 阴影 | boolean | false | 否 | 1.0.0 |
25 | | style | 自定义样式 | string | '' | 否 | 1.0.0 |
26 |
27 | 默认效果
28 |
29 | ```html
30 |
37 | 南山经之首曰䧿山。其首曰招摇之山,临于西海之上,多桂,多金玉。有草焉,其状如韭而青华,其名曰祝馀,食之不饥。有木焉,其状如榖而黑理,其华四照。其名曰迷榖,佩之不迷。有兽焉,其状如禺而白耳,伏行人走,其名曰狌狌,食之善走。丽麂之水出焉,而西流注于海,其中多育沛,佩之无瘕疾。
38 |
39 | ```
40 |
41 | 设置样式
42 |
43 | ```html
44 |
54 | 西山经华山之首,曰钱来之山,其上多松,其下多洗石。有兽焉,其状如羊而马尾,名曰羬羊,其脂可以已腊。
56 | 西四十五里,曰松果之山。濩水出焉,北流注于渭,其中多铜。有鸟焉,其名曰䳋渠,其状如山鸡,黑身赤足,可以已[月暴]。
58 | 又西六十里,曰太华之山,削成而四方,其高五千仞,其广十里,鸟兽莫居。有蛇焉,名曰肥(虫遗),六足四翼,见则天下大旱。
59 |
60 | ```
61 |
62 | 悬浮阴影
63 |
64 | ```html
65 |
72 | 《中山经》薄山之首,曰甘枣之山。共水出焉,而西流注于河。其上多杻木,其下有草焉,葵本而杏叶,黄华而荚实,名曰箨,可以已懵。有兽焉,其状如囗鼠而文题,其名曰㔮,食之已瘿。
73 |
74 | ```
--------------------------------------------------------------------------------
/miniprogram/components/Dialog/index.json:
--------------------------------------------------------------------------------
1 | {
2 | "component": true,
3 | "usingComponents": {}
4 | }
--------------------------------------------------------------------------------
/miniprogram/components/Dialog/index.wxml:
--------------------------------------------------------------------------------
1 |
7 |
8 |
13 |
17 |
22 |
23 |
24 |
25 |
29 | {{title}}
33 |
37 |
38 |
39 |
40 |
44 |
45 |
49 |
62 |
63 |
64 |
65 |
66 |
--------------------------------------------------------------------------------
/miniprogram/components/Dialog/package.json:
--------------------------------------------------------------------------------
1 | {
2 | "name": "@lightd/dialog",
3 | "cname":"对话框",
4 | "version": "1.0.0",
5 | "main": "index.js",
6 | "homepage": "https://github.com/MatrixAges/light-design/tree/master/miniprogram/components/Dialog",
7 | "author": "Matrixage",
8 | "license": "MIT"
9 | }
--------------------------------------------------------------------------------
/miniprogram/components/DialogQueue/index.json:
--------------------------------------------------------------------------------
1 | {
2 | "component": true,
3 | "usingComponents": {}
4 | }
--------------------------------------------------------------------------------
/miniprogram/components/DialogQueue/index.wxml:
--------------------------------------------------------------------------------
1 |
7 |
8 |
12 |
16 |
17 |
25 |
29 |
30 |
38 |
43 |
44 |
45 |
46 |
47 |
48 |
66 |
67 |
68 |
--------------------------------------------------------------------------------
/miniprogram/components/DialogQueue/package.json:
--------------------------------------------------------------------------------
1 | {
2 | "name": "@lightd/dialogqueue",
3 | "cname":"对话框队列",
4 | "version": "1.0.0",
5 | "main": "index.js",
6 | "homepage": "https://github.com/MatrixAges/light-design/tree/master/miniprogram/components/DialogQueue",
7 | "author": "Matrixage",
8 | "license": "MIT"
9 | }
--------------------------------------------------------------------------------
/miniprogram/components/DialogQueue/readme.md:
--------------------------------------------------------------------------------
1 |
2 |
3 | 对话框队列是并不是来自于对话框,原型来源于 Steam 客户端的首页“新闻”弹窗。她用于展示多个的媒体内容,通常是首页的优惠信息,以队列的方式而非多个弹窗的形式对用户更加友好。
4 |
5 | 使用场景
6 |
7 | - 首页展示多个优惠信息或者通知。
8 | - 展示步骤。
9 |
10 |
11 |
12 | | 属性 | 说明 | 类型 | 默认值 | 必填 | 版本 |
13 | | - | - | - | - | - | - |
14 | | visible | 是否可见 | boolean | false | 否 | 1.0.0 |
15 | | list | 数据项 | Array`` | [] | 是 | 1.0.0 |
16 | | zIndex | 层级 | number | 100 | 否 | 1.0.0 |
17 |
18 | types
19 |
20 | ```typescript
21 | type List = {
22 | rank:number
23 | title:string
24 | imgSrc: string
25 | target: string
26 | url: string
27 | appId: string
28 | version: string
29 | path: string
30 | daily: boolean
31 | durations: Array<{
32 | startTime: string
33 | endTime: string
34 | }>
35 | }
36 | ```
37 |
38 | list
39 |
40 | | 值 | 说明 | 版本 |
41 | | - | - | - |
42 | | rank | 排序值 | 1.0.0 |
43 | | title | 弹窗标题 | 1.0.0 |
44 | | imgSrc | 弹窗图片 | 1.0.0 |
45 | | target | 跳转类型 | 1.0.0 |
46 | | url | 跳转链接 | 1.0.0 |
47 | | appId | appId | 1.0.0 |
48 | | version | 版本 | 1.0.0 |
49 | | path | 路径 | 1.0.0 |
50 | | daily | 是否为每日弹窗 | 1.0.0 |
51 | | durations | 弹出时间 | 1.0.0 |
52 |
53 | > 当daily为true时,durations中startTime、endTime格式为18:00:00,当daily为false时,durations中startTime、endTime格式为2020/8/1 00:00:00
54 |
55 | 默认效果
56 |
57 | ```html
58 |
62 | ```
63 |
--------------------------------------------------------------------------------
/miniprogram/components/Icon/index.json:
--------------------------------------------------------------------------------
1 | {
2 | "component": true,
3 | "usingComponents": {}
4 | }
--------------------------------------------------------------------------------
/miniprogram/components/Icon/index.less:
--------------------------------------------------------------------------------
1 | .icon_wrap {
2 | display: flex;
3 | align-items: center;
4 | justify-content: center;
5 | box-sizing: border-box;
6 | }
7 |
8 | .icon {
9 | display: inline-block;
10 | background: black;
11 | vertical-align: middle;
12 |
13 | mask-repeat: no-repeat;
14 | mask-size: cover;
15 | }
--------------------------------------------------------------------------------
/miniprogram/components/Icon/index.ts:
--------------------------------------------------------------------------------
1 | Component( {
2 | options: {
3 | pureDataPattern: /^(type)$/
4 | },
5 | properties: {
6 | icon: {
7 | type: Object,
8 | value: {}
9 | } as {
10 | type: ObjectConstructor
11 | value: { outline: string; filled: string }
12 | },
13 | type: {
14 | type: String,
15 | value: 'outline'
16 | } as {
17 | type: StringConstructor
18 | value: 'outline' | 'filled'
19 | },
20 | size: {
21 | type: Number,
22 | value: 20
23 | },
24 | color: {
25 | type: String,
26 | value: '#000000'
27 | },
28 | visibleWrap: {
29 | type: Boolean,
30 | value: false
31 | },
32 | bordered: {
33 | type: Boolean,
34 | value: false
35 | },
36 | filled: {
37 | type: Boolean,
38 | value: false
39 | },
40 | round: {
41 | type: Boolean,
42 | value: false
43 | },
44 | borderColor: {
45 | type: String,
46 | value: 'whitesmoke'
47 | },
48 | fillColor: {
49 | type: String,
50 | value: 'whitesmoke'
51 | }
52 | },
53 | observers: {
54 | type ( v ) {
55 | this.getSrc( this.data.icon[ v ] )
56 | },
57 | icon ( v ) {
58 | if ( !v ) return
59 | if ( !this.data.type ) return
60 |
61 | this.getSrc( v[ this.data.type ] )
62 | }
63 | },
64 | data: {
65 | src: '',
66 | height: 20,
67 | width: 20
68 | },
69 | methods: {
70 | getSrc ( svg: string ) {
71 | if ( !svg ) return
72 |
73 | this.setData( {
74 | src: 'data:image/svg+xml,' + svg.replace( //g, '%3E' )
75 | } )
76 | }
77 | }
78 | } )
79 |
--------------------------------------------------------------------------------
/miniprogram/components/Icon/index.wxml:
--------------------------------------------------------------------------------
1 |
5 |
6 |
11 |
15 |
16 |
--------------------------------------------------------------------------------
/miniprogram/components/Icon/index.wxs:
--------------------------------------------------------------------------------
1 | function getWrapStyles( props ) {
2 | var styles = ''
3 |
4 | if ( props.bordered ) styles += ';border:2rpx solid ' + props.borderColor
5 | if ( props.filled ) styles += ';background:' + props.fillColor
6 | if ( props.round ) styles += ';border-radius:50%'
7 |
8 | styles += ';width:' + props.size * 1.5 + 'px'
9 | styles += ';height:' + props.size * 1.5 + 'px'
10 |
11 | return styles
12 | }
13 |
14 | function getStyles( props ) {
15 | var styles = ''
16 |
17 | styles += ';width:' + props.size + 'px'
18 | styles += ';height:' + props.size + 'px'
19 | styles += ';background:' + props.color
20 | styles += ';mask-image:url("' + props.src + '")'
21 | styles += ';-webkit-mask-image:url("' + props.src + '")'
22 |
23 | return styles
24 | }
25 |
26 | module.exports = {
27 | getWrapStyles: getWrapStyles,
28 | getStyles: getStyles
29 | }
--------------------------------------------------------------------------------
/miniprogram/components/Icon/package.json:
--------------------------------------------------------------------------------
1 | {
2 | "name": "@lightd/icon",
3 | "cname":"图标",
4 | "version": "1.0.0",
5 | "main": "index.js",
6 | "homepage": "https://github.com/MatrixAges/light-design/tree/master/miniprogram/components/Icon",
7 | "author": "Matrixage",
8 | "license": "MIT"
9 | }
--------------------------------------------------------------------------------
/miniprogram/components/Icon/readme.md:
--------------------------------------------------------------------------------
1 |
2 |
3 | 图标是对事物的一种抽象,用于对用户进行信息暗示,通过颜色和大小变化,对人的注意力进行不同程度的影响。图标在现代UI设计种是一种十分好用的元素。
4 |
5 | 使用场景
6 |
7 | - 配合按钮和表单项使用。
8 | - 配合菜单项目,对菜单内容进行暗示。
9 | - 作为超链接使用。
10 |
11 |
12 |
13 | | 属性 | 说明 | 类型 | 默认值 | 必填 | 版本 |
14 | | - | - | - | - | - | - |
15 | | icon | 图标 | Icon | {} | 是 | 1.0.0 |
16 | | type | 样式 | 'outline' or 'filled' | 'outline' | 否 | 1.0.0 |
17 | | size | 大小 | number | 20 | 否 | 1.0.0 |
18 | | color | 颜色 | string | '#000000' | 否 | 1.0.0 |
19 | | visibleWrap | 包裹 | boolean | false | 否 | 1.0.0 |
20 | | bordered | 边框 | boolean | false | 否 | 1.0.0 |
21 | | filled | 填充 | boolean | false | 否 | 1.0.0 |
22 | | round | 圆形 | boolean | false | 否 | 1.0.0 |
23 | | borderColor | 边框颜色 | string | 'whitesmoke' | 否 | 1.0.0 |
24 | | fillColor | 填充颜色 | string | 'whitesmoke' | 否 | 1.0.0 |
25 |
26 | 默认效果
27 |
28 | ```html
29 |
34 | ```
35 |
36 | 样式
37 |
38 | ```html
39 |
45 | ```
46 |
47 | 颜色
48 |
49 | ```html
50 |
56 | ```
57 |
58 | 渐变色
59 |
60 | ```html
61 |
67 | ```
68 |
69 | 大小
70 |
71 | ```html
72 |
78 | ```
79 |
80 | 包裹
81 |
82 | ```html
83 |
91 | ```
92 |
93 | 包裹样式
94 |
95 | ```html
96 |
106 | ```
--------------------------------------------------------------------------------
/miniprogram/components/Icon/rest/icon_types.ts:
--------------------------------------------------------------------------------
1 | export type Icon =
2 | | ''
3 | | 'add'
4 | | 'remove'
5 | | 'reload'
6 | | 'resize'
7 | | 'blockUp'
8 | | 'blockDown'
9 | | 'blockLeft'
10 | | 'blockRight'
11 | | 'arrowUp'
12 | | 'arrowDown'
13 | | 'arrowLeft'
14 | | 'arrowRight'
15 | | 'lineUp'
16 | | 'lineDown'
17 | | 'lineLeft'
18 | | 'lineRight'
19 | | 'alert'
20 | | 'close'
21 | | 'check'
22 | | 'sync'
23 | | 'arrowUpDown'
24 | | 'arrowLeftRight'
25 | | 'help'
26 | | 'ellipsisVert'
27 | | 'ellipsisHorizon'
28 | | 'toggle'
29 | | 'tag'
30 | | 'eye'
31 | | 'eyeOff'
32 | | 'doc'
33 | | 'cube'
34 | | 'create'
35 | | 'closeCircle'
36 | | 'checkCircle'
37 | | 'chat'
38 | | 'cart'
39 | | 'card'
40 | | 'camera'
41 | | 'call'
42 | | 'calendar'
43 | | 'location'
44 | | 'build'
45 | | 'book'
46 | | 'chart'
47 | | 'bag'
48 | | 'apps'
49 | | 'alarm'
50 | | 'circles'
51 | | 'ticket'
52 | | 'warning'
53 | | 'wallet'
54 | | 'unlink'
55 | | 'trash'
56 | | 'clock'
57 | | 'thumbUp'
58 | | 'thumbDown'
59 | | 'store'
60 | | 'star'
61 | | 'square'
62 | | 'share'
63 | | 'settings'
64 | | 'search'
65 | | 'save'
66 | | 'ribbon'
67 | | 'reader'
68 | | 'qrcode'
69 | | 'person'
70 | | 'options'
71 | | 'notification'
72 | | 'notificationOff'
73 | | 'navigate'
74 | | 'music'
75 | | 'mic'
76 | | 'micOff'
77 | | 'menu'
78 | | 'mail'
79 | | 'lockOpen'
80 | | 'lock'
81 | | 'locate'
82 | | 'list'
83 | | 'helpCircle'
84 | | 'heart'
85 | | 'headset'
86 | | 'happy'
87 | | 'grid'
88 | | 'gift'
89 | | 'game'
90 | | 'filter'
91 | | 'glag'
92 | | 'film'
93 | | 'woman'
94 | | 'man'
95 | | 'male'
96 | | 'female'
97 | | 'circle'
98 | | 'bluetooth'
99 |
100 | export type Data = Record
101 |
--------------------------------------------------------------------------------
/miniprogram/components/Landing/index.json:
--------------------------------------------------------------------------------
1 | {
2 | "component": true,
3 | "usingComponents": {}
4 | }
--------------------------------------------------------------------------------
/miniprogram/components/Landing/index.less:
--------------------------------------------------------------------------------
1 | @bg_color_landing: rgba(0, 0, 0, 0.9);
2 | @img_landing: url('');
3 |
4 | @keyframes light {
5 | from {
6 | clip: rect(60rpx 60rpx 60rpx 0);
7 | }
8 |
9 | to {
10 | clip: rect(0 60rpx 60rpx 0);
11 | }
12 | }
13 |
14 | .landing_wrap {
15 | position: fixed;
16 | top: 0;
17 | left: 0;
18 | display: flex;
19 | align-items: center;
20 | justify-content: center;
21 | width: 100vw;
22 | height: 100vh;
23 |
24 | .landing {
25 | position: relative;
26 | display: flex;
27 | align-items: center;
28 | flex-direction: column;
29 | justify-content: center;
30 | width: 180rpx;
31 | height: 180rpx;
32 | border-radius: 24rpx;
33 | background-color: @bg_color_landing;
34 |
35 | .icon {
36 | width: 60rpx;
37 | height: 60rpx;
38 | }
39 |
40 | .icon_source {
41 | width: 60rpx;
42 | height: 60rpx;
43 | background-image: @img_landing;
44 | background-size: 100% 100%;
45 | transform-origin: center bottom;
46 | }
47 |
48 | .icon_source_bottom {
49 | position: absolute;
50 | opacity: 0.3;
51 | }
52 |
53 | .icon_source_top {
54 | position: absolute;
55 | animation: light 1s infinite;
56 | }
57 | }
58 | }
--------------------------------------------------------------------------------
/miniprogram/components/Landing/index.ts:
--------------------------------------------------------------------------------
1 | Component( {
2 | options: {
3 | pureDataPattern: /^(visible|delay|timeout|timer_show|timer_hide)$/
4 | },
5 | properties: {
6 | visible: {
7 | type: Boolean,
8 | value: false
9 | },
10 | zIndex: {
11 | type: Number,
12 | value: 100
13 | },
14 | maskVisible: {
15 | type: Boolean,
16 | value: false
17 | },
18 | maskColor: {
19 | type: String,
20 | value: 'white'
21 | },
22 | delay: {
23 | type: Number,
24 | value: 0
25 | },
26 | timeout: {
27 | type: Number,
28 | value: 0
29 | }
30 | },
31 | data: {
32 | _visible: false,
33 | timer_show: 0,
34 | timer_hide: 0
35 | },
36 | observers: {
37 | visible ( new_val ) {
38 | const _that = this
39 | const { delay, timeout, timer_show, timer_hide } = _that.data
40 |
41 | clearTimeout( timer_show )
42 | clearTimeout( timer_hide )
43 |
44 | if ( new_val ) {
45 | const timer_show = setTimeout( () => {
46 | _that.setData( { _visible: true } )
47 | }, delay )
48 |
49 | _that.setData( { timer_show } )
50 | } else {
51 | const timer_hide = setTimeout( () => {
52 | _that.setData( { _visible: false } )
53 | }, timeout )
54 |
55 | _that.setData( { timer_hide } )
56 | }
57 | }
58 | },
59 | methods: {
60 | catchtouchmove () { },
61 | onShow () {
62 | const _that = this
63 |
64 | _that.setData( { visible: true } )
65 |
66 | _that.triggerEvent( 'onShow' )
67 | },
68 | onClose () {
69 | const _that = this
70 |
71 | _that.setData( { visible: false } )
72 |
73 | _that.triggerEvent( 'onClose' )
74 | }
75 | }
76 | } )
77 |
--------------------------------------------------------------------------------
/miniprogram/components/Landing/index.wxml:
--------------------------------------------------------------------------------
1 |
7 |
8 |
9 |
10 |
11 |
--------------------------------------------------------------------------------
/miniprogram/components/Landing/package.json:
--------------------------------------------------------------------------------
1 | {
2 | "name": "@lightd/landing",
3 | "cname":"页面加载",
4 | "version": "1.0.0",
5 | "main": "index.js",
6 | "homepage": "https://github.com/MatrixAges/light-design/tree/master/miniprogram/components/Landing",
7 | "author": "Matrixage",
8 | "license": "MIT"
9 | }
--------------------------------------------------------------------------------
/miniprogram/components/Landing/readme.md:
--------------------------------------------------------------------------------
1 |
2 |
3 | 页面加载的作用相当于一个落地页,避免应用在加载数据和渲染的过程中出现肉眼可见的闪烁,排版错乱。通过将品牌 Logo 设定为 Landing 的展示内容,加强用户对品牌的认知。
4 |
5 | 使用场景
6 |
7 | - 用户访问应用首页时。
8 | - 切换到新的页面数据还未加载完成时,用以代替占位符。
9 |
10 |
11 |
12 | | 属性 | 说明 | 类型 | 默认值 | 必填 | 版本 |
13 | | - | - | - | - | - | - |
14 | | visible | 是否可见 | boolean | false | 是 | 1.0.0 |
15 | | zIndex | 层级 | number | 100 | 否 | 1.0.0 |
16 | | maskVisible | 遮罩是否可见 | boolean | false | 否 | 1.0.0 |
17 | | maskColor | 遮罩颜色 | string | 'white' | 否 | 1.0.0 |
18 | | delay | 延迟显示时间 | number | 0 | 否 | 1.0.0 |
19 | | timeout | 延迟关闭时间 | number | 0 | 否 | 1.0.0 |
20 |
21 | 默认效果
22 |
23 | ```html
24 |
25 | ```
26 |
27 | 显示遮罩
28 |
29 | ```html
30 |
34 | ```
35 |
36 | 遮罩颜色
37 |
38 | ```html
39 |
44 | ```
--------------------------------------------------------------------------------
/miniprogram/components/Line/index.json:
--------------------------------------------------------------------------------
1 | {
2 | "component": true,
3 | "usingComponents": {}
4 | }
--------------------------------------------------------------------------------
/miniprogram/components/Line/index.less:
--------------------------------------------------------------------------------
1 | .init {
2 | color: black;
3 | font-size: 30rpx;
4 | line-height: 1.6;
5 | }
6 |
7 | .line_wrap {
8 | .init ();
9 |
10 | &.thin {
11 | transform: scaleY(0.5);
12 | }
13 |
14 | &.box {
15 | position: relative;
16 | display: flex;
17 | box-sizing: border-box;
18 |
19 | &.thin {
20 | transform: scaleY(1);
21 | }
22 | }
23 |
24 | .box {
25 | position: absolute;
26 | top: 0;
27 | left: 0;
28 | display: flex;
29 | box-sizing: border-box;
30 | width: 100%;
31 | height: 100%;
32 |
33 | &.thin {
34 | width: 200%;
35 | height: 200%;
36 | transform: scale(0.5);
37 | transform-origin: left top;
38 | }
39 | }
40 |
41 | }
--------------------------------------------------------------------------------
/miniprogram/components/Line/index.ts:
--------------------------------------------------------------------------------
1 | Component( {
2 | properties: {
3 | width: {
4 | type: String,
5 | value: '100%'
6 | },
7 | height: {
8 | type: String,
9 | value: '2rpx'
10 | },
11 | radius: {
12 | type: Number,
13 | value: 0
14 | },
15 | color: {
16 | type: String,
17 | value: 'black'
18 | },
19 | thin: {
20 | type: Boolean,
21 | value: false
22 | },
23 | box: {
24 | type: Boolean,
25 | value: false
26 | },
27 | borderSize: {
28 | type: Number,
29 | value: 2
30 | },
31 | }
32 | } )
33 |
--------------------------------------------------------------------------------
/miniprogram/components/Line/index.wxml:
--------------------------------------------------------------------------------
1 |
5 |
6 |
10 |
11 |
16 |
--------------------------------------------------------------------------------
/miniprogram/components/Line/index.wxs:
--------------------------------------------------------------------------------
1 | function getClasses( props ) {
2 | var classes = ''
3 |
4 | if ( props.thin ) classes += ' thin'
5 | if ( props.box ) classes += ' box'
6 |
7 | return classes
8 | }
9 |
10 | function getStyles( props ) {
11 | var styles = ''
12 |
13 | if ( props.box ) {
14 | styles += ';width:auto'
15 | styles += ';height:auto'
16 | styles += ';background-color:transparent'
17 | } else {
18 | if ( props.width ) styles += ';width:' + props.width
19 | if ( props.height ) styles += ';height:' + props.height
20 | if ( props.color ) styles += ';background-color:' + props.color
21 | }
22 |
23 | styles += ';border-radius:' + props.radius + 'rpx'
24 |
25 | return styles
26 | }
27 |
28 | function getContentStyles( props ) {
29 | var styles = ''
30 |
31 | styles += ';border:' + props.borderSize + 'rpx solid ' + props.color
32 | styles += ';border-radius:' + props.radius * ( props.thin ? 2 : 1 ) + 'rpx'
33 |
34 | return styles
35 | }
36 |
37 | module.exports = {
38 | getClasses: getClasses,
39 | getStyles: getStyles,
40 | getContentStyles: getContentStyles
41 | }
--------------------------------------------------------------------------------
/miniprogram/components/Line/package.json:
--------------------------------------------------------------------------------
1 | {
2 | "name": "@lightd/line",
3 | "cname":"线条",
4 | "version": "1.0.0",
5 | "main": "index.js",
6 | "homepage": "https://github.com/MatrixAges/light-design/tree/master/miniprogram/components/Line",
7 | "author": "Matrixage",
8 | "license": "MIT"
9 | }
--------------------------------------------------------------------------------
/miniprogram/components/Line/readme.md:
--------------------------------------------------------------------------------
1 |
2 |
3 | 线条是原子化的元素,可用来包裹其他任何类型的子元素,且能够单独使用。
4 |
5 | 使用场景
6 |
7 | - 需要设定0.5px线条时。
8 | - 包裹内容,以代替 border。
9 |
10 |
11 |
12 | | 属性 | 说明 | 类型 | 默认值 | 必填 | 版本 |
13 | | - | - | - | - | - | - |
14 | | width | 宽度 | string | '100%' | 否 | 1.0.0 |
15 | | height | 高度 | string | '2rpx' | 否 | 1.0.0 |
16 | | radius | 圆角 | number | 0 | 否 | 1.0.0 |
17 | | color | 颜色 | string | 'black' | 否 | 1.0.0 |
18 | | thin | 0.5px边界 | boolean | false | 否 | 1.0.0 |
19 | | box | 包裹对象 | boolean | false | 否 | 1.0.0 |
20 | | borderSize | 边界大小 | number | 2 | 否 | 1.0.0 |
21 |
22 | 默认效果
23 |
24 | ```html
25 |
26 | ```
27 |
28 | 设定宽度
29 |
30 | ```html
31 |
32 | ```
33 |
34 | 设定高度
35 |
36 | ```html
37 |
38 | ```
39 |
40 | 0.5px线条
41 |
42 | ```html
43 |
44 | ```
45 |
46 | 设定圆角
47 |
48 | ```html
49 |
53 | ```
54 |
55 | 配合使用
56 |
57 | ```html
58 |
65 |
66 |
67 | ```
68 |
69 | 包裹对象
70 |
71 | ```html
72 |
76 |
80 | Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor
81 | incididunt
82 | ut labore et dolore magna aliqua.
83 |
84 |
85 | ```
86 |
87 | 0.5px边界
88 |
89 | ```html
90 |
95 |
99 | Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor
100 | incididunt
101 | ut labore et dolore magna aliqua.
102 |
103 |
104 | ```
105 |
106 | 边界颜色
107 |
108 | ```html
109 |
114 |
118 | Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor
119 | incididunt
120 | ut labore et dolore magna aliqua.
121 |
122 |
123 | ```
124 |
--------------------------------------------------------------------------------
/miniprogram/components/Loading/index.json:
--------------------------------------------------------------------------------
1 | {
2 | "component": true,
3 | "usingComponents": {}
4 | }
--------------------------------------------------------------------------------
/miniprogram/components/Loading/index.less:
--------------------------------------------------------------------------------
1 | @import './style/refresh.wxss';
2 | @import './style/loading.wxss';
3 |
4 | .loading_wrap {
5 | display: flex;
6 | align-items: center;
7 | flex-direction: column;
8 |
9 | .text {
10 | margin-top: 20rpx;
11 | color: black;
12 | font-size: 24rpx;
13 | }
14 | }
--------------------------------------------------------------------------------
/miniprogram/components/Loading/index.ts:
--------------------------------------------------------------------------------
1 | Component( {
2 | options: {
3 | pureDataPattern: /^(visible|delay|timeout|timer_show|timer_hide)$/
4 | },
5 | properties: {
6 | visible: {
7 | type: Boolean,
8 | value: false
9 | },
10 | type: {
11 | type: String,
12 | value: 'refresh'
13 | } as {
14 | type: StringConstructor
15 | value: 'refresh' | 'loading'
16 | },
17 | size: {
18 | type: Number,
19 | value: 1
20 | },
21 | text: {
22 | type: String,
23 | value: ''
24 | },
25 | delay: {
26 | type: Number,
27 | value: 0
28 | },
29 | timeout: {
30 | type: Number,
31 | value: 0
32 | }
33 | },
34 | data: {
35 | _visible: false,
36 | timer_show: 0,
37 | timer_hide: 0
38 | },
39 | observers: {
40 | visible ( new_val ) {
41 | const _that = this
42 | const { delay, timeout, timer_show, timer_hide } = _that.data
43 |
44 | clearTimeout( timer_show )
45 | clearTimeout( timer_hide )
46 |
47 | if ( new_val ) {
48 | const timer_show = setTimeout( () => {
49 | _that.setData( { _visible: true } )
50 | }, delay )
51 |
52 | _that.setData( { timer_show } )
53 | } else {
54 | const timer_hide = setTimeout( () => {
55 | _that.setData( { _visible: false } )
56 | }, timeout )
57 |
58 | _that.setData( { timer_hide } )
59 | }
60 | }
61 | },
62 | methods: {
63 | onShow () {
64 | const _that = this
65 |
66 | _that.setData( { visible: true } )
67 |
68 | _that.triggerEvent( 'onShow' )
69 | },
70 | onClose () {
71 | const _that = this
72 |
73 | _that.setData( { visible: false } )
74 |
75 | _that.triggerEvent( 'onClose' )
76 | }
77 | }
78 | } )
79 |
--------------------------------------------------------------------------------
/miniprogram/components/Loading/index.wxml:
--------------------------------------------------------------------------------
1 |
6 |
7 | {{text}}
11 |
--------------------------------------------------------------------------------
/miniprogram/components/Loading/package.json:
--------------------------------------------------------------------------------
1 | {
2 | "name": "@lightd/loading",
3 | "cname":"加载中",
4 | "version": "1.0.0",
5 | "main": "index.js",
6 | "homepage": "https://github.com/MatrixAges/light-design/tree/master/miniprogram/components/Loading",
7 | "author": "Matrixage",
8 | "license": "MIT"
9 | }
--------------------------------------------------------------------------------
/miniprogram/components/Loading/readme.md:
--------------------------------------------------------------------------------
1 |
2 |
3 | 加载中用来表示数据加载状态,主要用来缓解用户焦虑,她时连续性设计的一部分。
4 |
5 | 使用场景
6 |
7 | - 配合按钮进行使用。
8 | - 当加载列表数据项时。
9 |
10 |
11 |
12 | | 属性 | 说明 | 类型 | 默认值 | 必填 | 版本 |
13 | | - | - | - | - | - | - |
14 | | visible | 是否可见 | boolean | false | 否 | 1.0.0 |
15 | | type | 类型 | 'refresh' or 'loading' | 'refresh' | 否 | 1.0.0 |
16 | | size | 大小 | number | 1 | 否 | 1.0.0 |
17 | | text | 文字 | string | '' | 否 | 1.0.0 |
18 | | delay | 延迟显示时间 | number | 0 | 否 | 1.0.0 |
19 | | timeout | 延迟关闭时间 | number | 0 | 否 | 1.0.0 |
20 |
21 | 默认效果
22 |
23 | ```html
24 |
28 | ```
29 |
30 | 加载中
31 |
32 | ```html
33 |
37 | ```
--------------------------------------------------------------------------------
/miniprogram/components/Loading/style/loading.less:
--------------------------------------------------------------------------------
1 | @color: black;
2 | @color_bg: whitesmoke;
3 | @size: 16rpx;
4 |
5 | @keyframes loading_loading {
6 | 0% {
7 | background: fade(@color, 10);
8 | }
9 |
10 | 20% {
11 | background: fade(@color, 100);
12 | }
13 |
14 | 60% {
15 | background: fade(@color, 10);
16 | }
17 | }
18 |
19 | .loading_loading:not(:required) {
20 | position: relative;
21 | display: inline-block;
22 | width: @size;
23 | height: @size;
24 | border-radius: 50%;
25 | background: @color_bg;
26 | text-indent: -9999px;
27 | animation: loading_loading 2000ms 300ms infinite ease-out;
28 | }
29 |
30 | .loading_loading:not(:required):before,
31 | .loading_loading:not(:required):after {
32 | position: absolute;
33 | top: 0;
34 | display: inline-block;
35 | width: @size;
36 | height: @size;
37 | border-radius: 50%;
38 | background: @color_bg;
39 | content: '';
40 | }
41 |
42 | .loading_loading:not(:required):before {
43 | left: -@size*2;
44 | animation: loading_loading 2000ms 150ms infinite ease-out;
45 | }
46 |
47 | .loading_loading:not(:required):after {
48 | right: -@size*2;
49 | animation: loading_loading 2000ms 450ms infinite ease-out;
50 | }
--------------------------------------------------------------------------------
/miniprogram/components/Loading/style/loading.wxss:
--------------------------------------------------------------------------------
1 | @keyframes loading_loading {
2 | 0% {
3 | background: rgba(0, 0, 0, 0.1);
4 | }
5 |
6 | 20% {
7 | background: rgba(0, 0, 0, 1.0);
8 | }
9 |
10 | 60% {
11 | background: rgba(18, 18, 18, 0.1);
12 | }
13 | }
14 |
15 | .loading_loading:not(:required) {
16 | position: relative;
17 | display: inline-block;
18 | width: 16rpx;
19 | height: 16rpx;
20 | border-radius: 50%;
21 | background: whitesmoke;
22 | text-indent: -9999px;
23 | animation: loading_loading 2000ms 300ms infinite ease-out;
24 | }
25 |
26 | .loading_loading:not(:required):before,
27 | .loading_loading:not(:required):after {
28 | position: absolute;
29 | top: 0;
30 | display: inline-block;
31 | width: 16rpx;
32 | height: 16rpx;
33 | border-radius: 50%;
34 | background: whitesmoke;
35 | content: '';
36 | }
37 |
38 | .loading_loading:not(:required):before {
39 | left: -32rpx;
40 | animation: loading_loading 2000ms 150ms infinite ease-out;
41 | }
42 |
43 | .loading_loading:not(:required):after {
44 | right: -32rpx;
45 | animation: loading_loading 2000ms 450ms infinite ease-out;
46 | }
--------------------------------------------------------------------------------
/miniprogram/components/Loading/style/refresh.less:
--------------------------------------------------------------------------------
1 | @color: fade(black, 100);
2 |
3 | @keyframes loading_refresh {
4 | 0% {
5 | transform: rotate(0deg);
6 | }
7 |
8 | 100% {
9 | transform: rotate(360deg);
10 | }
11 | }
12 |
13 | .loading_refresh:not(:required) {
14 | display: inline-block;
15 | width: 48rpx;
16 | height: 48rpx;
17 | border: 8rpx solid @color;
18 | border-left-color: transparent;
19 | border-radius: 50%;
20 | color: transparent;
21 | text-indent: 100%;
22 | line-height: 1.2;
23 | animation: loading_refresh 1000ms infinite linear;
24 | }
--------------------------------------------------------------------------------
/miniprogram/components/Loading/style/refresh.wxss:
--------------------------------------------------------------------------------
1 | @keyframes loading_refresh {
2 | 0% {
3 | transform: rotate(0deg);
4 | }
5 |
6 | 100% {
7 | transform: rotate(360deg);
8 | }
9 | }
10 |
11 | .loading_refresh:not(:required) {
12 | display: inline-block;
13 | width: 48rpx;
14 | height: 48rpx;
15 | border: 8rpx solid rgba(0, 0, 0, 1.0);
16 | border-left-color: transparent;
17 | border-radius: 50%;
18 | color: transparent;
19 | text-indent: 100%;
20 | line-height: 1.2;
21 | animation: loading_refresh 1000ms infinite linear;
22 | }
--------------------------------------------------------------------------------
/miniprogram/components/Modal/index.json:
--------------------------------------------------------------------------------
1 | {
2 | "component": true,
3 | "usingComponents": {}
4 | }
--------------------------------------------------------------------------------
/miniprogram/components/Modal/index.less:
--------------------------------------------------------------------------------
1 | .init {
2 | color: black;
3 | font-size: 30rpx;
4 | line-height: 1.6;
5 | }
6 |
7 | .fixed_dialog_wrap {
8 | position: fixed;
9 | top: 0;
10 | left: 0;
11 | width: 100vw;
12 | height: 100vh;
13 |
14 | .init();
15 |
16 | .dialog_wrap {
17 | position: relative;
18 | display: flex;
19 | align-items: center;
20 | justify-content: center;
21 | width: 100%;
22 | height: 100%;
23 |
24 | .mask {
25 | position: absolute;
26 | top: 0;
27 | left: 0;
28 | width: 100%;
29 | height: 100%;
30 | transition: all ease 0.3s;
31 | }
32 |
33 | .dialog {
34 | display: flex;
35 | transition: all ease 0.3s;
36 |
37 | &.top {
38 | position: absolute;
39 | top: 0;
40 | }
41 |
42 | &.bottom {
43 | position: absolute;
44 | bottom: 0;
45 | padding-bottom: env(safe-area-inset-bottom);
46 | }
47 |
48 | &.left {
49 | position: absolute;
50 | left: 0;
51 | }
52 |
53 | &.right {
54 | position: absolute;
55 | right: 0;
56 | }
57 | }
58 | }
59 | }
--------------------------------------------------------------------------------
/miniprogram/components/Modal/index.wxml:
--------------------------------------------------------------------------------
1 |
7 |
8 |
13 |
17 |
18 |
19 |
20 |
21 |
22 |
23 |
--------------------------------------------------------------------------------
/miniprogram/components/Modal/package.json:
--------------------------------------------------------------------------------
1 | {
2 | "name": "@lightd/modal",
3 | "cname":"弹层",
4 | "version": "1.0.0",
5 | "main": "index.js",
6 | "homepage": "https://github.com/MatrixAges/light-design/tree/master/miniprogram/components/Modal",
7 | "author": "Matrixage",
8 | "license": "MIT"
9 | }
--------------------------------------------------------------------------------
/miniprogram/components/Modal/readme.md:
--------------------------------------------------------------------------------
1 |
2 |
3 | 加载中用来表示数据加载状态,对页面的不同内容之间进行过渡,她是连续性设计的一部分。
4 |
5 | 使用场景
6 |
7 | - 配合按钮进行使用。
8 | - 当加载列表数据项时。
9 |
10 |
11 |
12 | | 属性 | 说明 | 类型 | 默认值 | 必填 | 版本 |
13 | | - | - | - | - | - | - |
14 | | visible | 是否可见 | boolean | false | 否 | 1.0.0 |
15 | | position | 弹出位置 | enum_position | false | 否 | 1.0.0 |
16 | | zIndex | 层级 | number | 100 | 否 | 1.0.0 |
17 | | duration | 过渡时间 | number | 300 | 否 | 1.0.0 |
18 | | maskVisible | 遮罩是否可见 | boolean | true | 否 | 1.0.0 |
19 | | maskClosable | 点击遮罩关闭 | boolean | true | 否 | 1.0.0 |
20 |
21 | types
22 |
23 | ```typescript
24 | type enum_position = 'center' | 'top' | 'bottom' | 'left' | 'right'
25 | ```
26 |
27 | triggerEvents
28 |
29 | ```typescript
30 | // 展示时触发
31 | onShow:()=>void
32 |
33 | // 隐藏时触发
34 | onClose:()=>void
35 |
36 | ```
37 |
38 | 默认效果
39 |
40 | ```html
41 |
42 | 居中显示的内容
43 |
44 | ```
45 |
46 | 顶部弹出
47 |
48 | ```html
49 |
53 | 居中显示的内容
54 |
55 | ```
56 |
57 | 底部弹出
58 |
59 | ```html
60 |
64 | 居中显示的内容
65 |
66 | ```
67 |
68 | 左侧弹出
69 |
70 | ```html
71 |
75 | 居中显示的内容
76 |
77 | ```
78 |
79 | 右侧弹出
80 |
81 | ```html
82 |
86 | 居中显示的内容
87 |
88 | ```
89 |
90 | 没有遮罩
91 |
92 | ```html
93 |
97 | 居中显示的内容
98 |
99 | ```
100 |
101 | 蒙层关闭
102 |
103 | ```html
104 |
108 | 居中显示的内容
109 |
110 | ```
--------------------------------------------------------------------------------
/miniprogram/components/NoticeBar/index.json:
--------------------------------------------------------------------------------
1 | {
2 | "component": true,
3 | "usingComponents": {}
4 | }
--------------------------------------------------------------------------------
/miniprogram/components/NoticeBar/index.less:
--------------------------------------------------------------------------------
1 | @height: 60rpx;
2 |
3 | .notice_wrap {
4 | display: flex;
5 | align-items: center;
6 | box-sizing: border-box;
7 | padding: 0 12rpx;
8 | width: 100%;
9 |
10 | .left_wrap {
11 | display: flex;
12 | align-items: center;
13 | justify-content: center;
14 | width: 60rpx;
15 |
16 | .icon_notice {
17 | width: 40rpx;
18 | height: 40rpx;
19 | }
20 | }
21 |
22 | .content {
23 | box-sizing: border-box;
24 | padding: 0 8rpx;
25 | width: calc(~'100% - 60rpx - 40rpx');
26 |
27 | .swiper {
28 | height: @height;
29 |
30 | &.horizontal {
31 | .swiper_item {
32 | .item {
33 | display: inline;
34 | overflow: visible;
35 | box-sizing: border-box;
36 | padding-left: 24rpx;
37 | width: auto;
38 |
39 | &:nth-of-type(1){
40 | padding-left: 0;
41 | }
42 | }
43 | }
44 | }
45 |
46 | .swiper_item {
47 | width: 100%;
48 | height: 100%;
49 |
50 | .item {
51 | display: -webkit-box;
52 | overflow: hidden;
53 | -webkit-box-orient: vertical;
54 | width: 100%;
55 | height: @height;
56 | font-size: 24rpx;
57 | line-height: @height;
58 |
59 | -webkit-line-clamp: 1;
60 | }
61 | }
62 | }
63 | }
64 |
65 | .right_wrap {
66 | display: flex;
67 | align-items: center;
68 | justify-content: flex-end;
69 | width: 40rpx;
70 |
71 | .icon_right {
72 | width: 32rpx;
73 | height: 32rpx;
74 | opacity: 0.6;
75 | }
76 | }
77 | }
--------------------------------------------------------------------------------
/miniprogram/components/NoticeBar/index.ts:
--------------------------------------------------------------------------------
1 | import icons from './rest/icons'
2 |
3 | Component( {
4 | properties: {
5 | list: {
6 | type: Array,
7 | value: []
8 | } as {
9 | type: ArrayConstructor
10 | value: Array
11 | },
12 | horizontal: {
13 | type: Boolean,
14 | value: false
15 | },
16 | color: {
17 | type: String,
18 | value: 'black'
19 | },
20 | bgColor: {
21 | type: String,
22 | value: 'whitesmoke'
23 | },
24 | styles: {
25 | type: String,
26 | value: ''
27 | },
28 | interval: {
29 | type: Number,
30 | value: 3000
31 | }
32 | },
33 | data: {
34 | icon_notice: `"data:image/svg+xml,${ icons.iconNotice
35 | .replace( //g, '%3E' ) }"`,
37 | icon_right: `"data:image/svg+xml,${ icons.iconRight
38 | .replace( //g, '%3E' ) }"`
40 | },
41 | methods: {
42 | catchtouchmove () { },
43 | onDetail ( { mark: { index } } ) {
44 | if ( index === undefined ) return
45 |
46 | this.triggerEvent( 'onDetail', { index } )
47 | },
48 | onMore () {
49 | this.triggerEvent( 'onMore' )
50 | }
51 | }
52 | } )
53 |
--------------------------------------------------------------------------------
/miniprogram/components/NoticeBar/index.wxml:
--------------------------------------------------------------------------------
1 |
5 |
6 |
10 |
11 |
15 |
16 |
20 |
29 |
33 |
38 | {{item}}
44 |
45 |
46 |
47 |
48 |
52 |
56 |
57 |
--------------------------------------------------------------------------------
/miniprogram/components/NoticeBar/index.wxs:
--------------------------------------------------------------------------------
1 | function getStyles( props ) {
2 | var styles = ''
3 |
4 | if ( props.color ) styles += ';color:' + props.color
5 | if ( props.bgColor ) styles += ';background:' + props.bgColor
6 |
7 | return styles
8 | }
9 |
10 | module.exports = {
11 | getStyles: getStyles
12 | }
--------------------------------------------------------------------------------
/miniprogram/components/NoticeBar/package.json:
--------------------------------------------------------------------------------
1 | {
2 | "name": "@lightd/noticebar",
3 | "cname":"提示栏",
4 | "version": "1.0.0",
5 | "main": "index.js",
6 | "homepage": "https://github.com/MatrixAges/light-design/tree/master/miniprogram/components/NoticeBar",
7 | "author": "Matrixage",
8 | "license": "MIT"
9 | }
--------------------------------------------------------------------------------
/miniprogram/components/NoticeBar/readme.md:
--------------------------------------------------------------------------------
1 |
2 |
3 | 公告栏的灵感来源于现实世界的文字滚动LED屏幕,她是公告中心的功能延伸。
4 |
5 | 使用场景
6 |
7 | - 在应用首页展示滚动新闻。
8 | - 作为悬浮栏固定在页面顶部,展示公告信息。
9 |
10 |
11 |
12 | | 属性 | 说明 | 类型 | 默认值 | 必填 | 版本 |
13 | | - | - | - | - | - | - |
14 | | list | 数据项 | boolean | false | 否 | 1.0.0 |
15 | | horizontal | 横向滚动 | boolean | false | 否 | 1.0.0 |
16 | | color | 颜色 | string | 'black' | 否 | 1.0.0 |
17 | | bgColor | 背景 | string | 'whitesmoke' | 否 | 1.0.0 |
18 | | styles | 自定义样式 | string | '' | 否 | 1.0.0 |
19 | | interval | 时间间隔 | number | 3000 | 否 | 1.0.0 |
20 | | duration | 时间间隔 | number | 3000 | 否 | 1.0.0 |
21 |
22 | triggerEvents
23 |
24 | ```typescript
25 | // 点击滚动项时触发
26 | onDetail:(
27 | {
28 | detail: {
29 | index
30 | }:{
31 | index:number
32 | }
33 | }
34 | )=>void
35 |
36 | // 点击更多时触发
37 | onMore:()=>void
38 | ```
39 |
40 | 默认效果
41 |
42 | ```html
43 |
44 | ```
45 |
46 | 横向滚动
47 |
48 | ```html
49 |
54 | ```
55 |
56 | 颜色
57 |
58 | ```html
59 |
64 | ```
65 |
66 | 背景
67 |
68 | ```html
69 |
74 | ```
75 |
76 | 时间间隔
77 |
78 | ```html
79 |
83 | ```
84 |
85 | 自定义样式
86 |
87 | ```html
88 |
92 | ```
--------------------------------------------------------------------------------
/miniprogram/components/NoticeBar/rest/icons.ts:
--------------------------------------------------------------------------------
1 | export default {
2 | iconNotice:``,
3 | iconRight:``
4 | }
--------------------------------------------------------------------------------
/miniprogram/components/Period/index.json:
--------------------------------------------------------------------------------
1 | {
2 | "component": true,
3 | "usingComponents": {}
4 | }
--------------------------------------------------------------------------------
/miniprogram/components/Period/index.wxml:
--------------------------------------------------------------------------------
1 |
7 |
8 |
12 |
13 |
17 |
18 | {{title}}
19 |
20 |
21 |
27 |
34 |
35 |
41 |
48 |
49 |
50 |
51 |
55 |
56 |
57 |
58 |
--------------------------------------------------------------------------------
/miniprogram/components/Period/package.json:
--------------------------------------------------------------------------------
1 | {
2 | "name": "@lightd/period",
3 | "cname":"预约选择器",
4 | "version": "1.0.0",
5 | "main": "index.js",
6 | "homepage": "https://github.com/MatrixAges/light-design/tree/master/miniprogram/components/Period",
7 | "author": "Matrixage",
8 | "license": "MIT"
9 | }
--------------------------------------------------------------------------------
/miniprogram/components/Period/readme.md:
--------------------------------------------------------------------------------
1 |
2 |
3 | 预约选择器来自于快递预约业务,是用来预约时间的组件。
4 |
5 | 使用场景
6 |
7 | - 快递提交包裹时,预约时间选择。
8 | - 提前预定外卖。
9 | - 预约送货上门时间。
10 |
11 |
12 |
13 | | 属性 | 说明 | 类型 | 默认值 | 必填 | 版本 |
14 | | - | - | - | - | - | - |
15 | | visible | 是否可见 | boolean | false | 否 | 1.0.0 |
16 | | title | 标题 | string | '预约上门时间' | 否 | 1.0.0 |
17 | | zIndex | 层级 | number | 100 | 否 | 1.0.0 |
18 | | showTwoHours | 两小时以内 | boolean | false | 否 | 1.0.0 |
19 | | timeItems | 时间范围 | Array`` | [] | 否 | 1.0.0 |
20 | | days | 天数 | number | 0 | 否 | 1.0.0 |
21 | | startTime | 开始时间 | number | 0 | 否 | 1.0.0 |
22 | | endTime | 结束时间 | number | 0 | 否 | 1.0.0 |
23 | | duration | 时间间隔 | number | 0 | 否 | 1.0.0 |
24 |
25 | types
26 |
27 | ```typescript
28 | interface IDate {
29 | raw: Date
30 | text: string
31 | }
32 |
33 | type ITime = {
34 | raw: { from: number; to: number }
35 | text: string
36 | }
37 | ```
38 |
39 | triggerEvents
40 |
41 | ```ts
42 | onSelectedPeriod:(
43 | {
44 | detail: {
45 | date,
46 | time
47 | }:{
48 | date:Array
49 | time:Array
50 | }
51 | }
52 | )=>void
53 | ```
54 |
55 | 默认效果
56 |
57 | ```html
58 |
65 |
66 | ```
67 |
68 | 设置日期范围
69 |
70 | ```html
71 |
78 |
79 | ```
80 |
81 | 设置时间范围
82 |
83 | ```html
84 |
91 |
92 | ```
93 |
94 | 直接设置时间
95 |
96 | ```html
97 |
102 |
103 | ```
104 |
105 | 两小时以内
106 |
107 | ```html
108 |
116 |
117 | ```
118 |
119 | 获取数据
120 |
121 | ```html
122 |
131 |
132 | ```
133 |
134 |
--------------------------------------------------------------------------------
/miniprogram/components/Popover/index.json:
--------------------------------------------------------------------------------
1 | {
2 | "component": true,
3 | "usingComponents": {}
4 | }
--------------------------------------------------------------------------------
/miniprogram/components/Popover/index.less:
--------------------------------------------------------------------------------
1 | .init {
2 | font-size: 14px;
3 | line-height: 1;
4 | }
5 |
6 | .fixed_dialog_wrap {
7 | position: fixed;
8 | top: 0;
9 | left: 0;
10 |
11 | .init();
12 |
13 | .mask {
14 | position: absolute;
15 | top: 0;
16 | left: 0;
17 | width: 100vw;
18 | height: 100vh;
19 | }
20 |
21 | .dialog {
22 | position: fixed;
23 | display: flex;
24 | flex-direction: column;
25 | border-radius: 12rpx;
26 | transition: all ease 0.15s;
27 |
28 | &.visible {
29 | opacity: 1;
30 | transform: scale(1);
31 | }
32 |
33 | &.hidden {
34 | opacity: 0;
35 | transform: scale(0.72);
36 | }
37 |
38 | .mark {
39 | position: absolute;
40 | width: 20rpx;
41 | height: 20rpx;
42 | border-radius: 4rpx;
43 | transform: rotate(45deg);
44 | }
45 |
46 | .action_item {
47 | display: flex;
48 | align-items: center;
49 | margin: 0;
50 | padding: 0;
51 | padding-left: 32rpx;
52 | width: auto;
53 | height: auto;
54 | border: none;
55 | border-radius: 0;
56 | background-color: transparent;
57 | text-align: left;
58 | font-weight: normal;
59 | transition: all ease 0s;
60 |
61 | .init();
62 |
63 | &:first-of-type {
64 | border-top-left-radius: 12rpx;
65 | border-top-right-radius: 12rpx;
66 | }
67 |
68 | &:last-child {
69 | border-bottom-right-radius: 12rpx;
70 | border-bottom-left-radius: 12rpx;
71 |
72 | .name {
73 | border-bottom: 2rpx solid transparent !important;
74 | }
75 | }
76 |
77 | &:active {
78 | background-color: #333;
79 |
80 | .name {
81 | border-bottom: 2rpx solid transparent !important;
82 | }
83 | }
84 |
85 | &::after {
86 | display: none;
87 | }
88 |
89 | .icon_wrap {
90 | display: flex;
91 | align-items: center;
92 | justify-content: left;
93 | padding-right: 24rpx;
94 | width: 40rpx;
95 |
96 | .icon_action {
97 | width: 38rpx;
98 | height: 38rpx;
99 | }
100 | }
101 |
102 | .name {
103 | padding: 32rpx 0;
104 | width: 180rpx;
105 | height: 100%;
106 | }
107 | }
108 | }
109 | }
--------------------------------------------------------------------------------
/miniprogram/components/Popover/index.ts:
--------------------------------------------------------------------------------
1 | Component( {
2 | options: {
3 | pureDataPattern: /^(visible|timer_close)$/
4 | },
5 | properties: {
6 | visible: {
7 | type: Boolean,
8 | value: false
9 | },
10 | position: {
11 | type: Array,
12 | value: [ '', '', '', '' ] // top , bottom , left , right
13 | } as {
14 | type: ArrayConstructor
15 | value: [ string, string, string, string ]
16 | },
17 | mark: {
18 | type: Array,
19 | value: [ '-8rpx', '', '', '30rpx' ] // top , bottom , left , right
20 | } as {
21 | type: ArrayConstructor
22 | value: [ string, string, string, string ]
23 | },
24 | transformOrigin: {
25 | type: String,
26 | value: 'top right'
27 | },
28 | list: {
29 | type: Array,
30 | value: []
31 | } as {
32 | type: ArrayConstructor
33 | value: Array<{
34 | name: String
35 | icon: String
36 | }>
37 | },
38 | bgColor: {
39 | type: String,
40 | value: 'black'
41 | },
42 | color: {
43 | type: String,
44 | value: 'white'
45 | },
46 | divideColor: {
47 | type: String,
48 | value: 'rgba(255, 255, 255, 0.15)'
49 | },
50 | zIndex: {
51 | type: Number,
52 | value: 100
53 | }
54 | },
55 | data: {
56 | _visible_dialog_wrap: false,
57 | _visible_dialog: false,
58 | timer_close: 0
59 | },
60 | observers: {
61 | visible ( new_val ) {
62 | const _that = this
63 |
64 | clearTimeout( _that.data.timer_close )
65 |
66 | if ( new_val ) {
67 | _that.setData( { _visible_dialog_wrap: true }, () => {
68 | _that.setData( { _visible_dialog: true } )
69 | } )
70 | } else {
71 | _that.setData( { _visible_dialog: false } )
72 |
73 | const timer_close = setTimeout( () => {
74 | _that.setData( { _visible_dialog_wrap: false } )
75 | }, 150 )
76 |
77 | _that.setData( { timer_close } )
78 | }
79 | }
80 | },
81 | methods: {
82 | catchtouchmove () { },
83 | onActionItem ( e ) {
84 | const _that = this
85 | const { mark: { index } } = e
86 |
87 | if ( index === undefined ) return
88 |
89 | _that.setData( { visible: false } )
90 |
91 | _that.triggerEvent( 'onOption', { index: index } )
92 | },
93 | onShow () {
94 | const _that = this
95 |
96 | _that.setData( { visible: true } )
97 |
98 | _that.triggerEvent( 'onShow' )
99 | },
100 | onClose () {
101 | const _that = this
102 |
103 | _that.setData( { visible: false } )
104 |
105 | _that.triggerEvent( 'onClose' )
106 | }
107 | }
108 | } )
109 |
--------------------------------------------------------------------------------
/miniprogram/components/Popover/index.wxml:
--------------------------------------------------------------------------------
1 |
5 |
6 |
12 |
16 |
21 |
25 |
47 |
48 |
--------------------------------------------------------------------------------
/miniprogram/components/Popover/index.wxs:
--------------------------------------------------------------------------------
1 | function formatName( name ) {
2 | return name.substring( 0, 5 )
3 | }
4 |
5 | function getDialogStyles( props ) {
6 | var styles = ''
7 |
8 | if ( props.position ) {
9 | if ( props.position[ 0 ] ) styles += ';top:' + props.position[ 0 ]
10 | if ( props.position[ 1 ] ) styles += ';bottom:' + props.position[ 1 ]
11 | if ( props.position[ 2 ] ) styles += ';left:' + props.position[ 2 ]
12 | if ( props.position[ 3 ] ) styles += ';right:' + props.position[ 3 ]
13 | }
14 |
15 | styles += ';color:' + props.color
16 | styles += ';background:' + props.bgColor
17 | styles += ';transform-origin:' + props.transformOrigin
18 |
19 | return styles
20 | }
21 |
22 | function getMarkStyles( props ) {
23 | var styles = ''
24 |
25 | if ( props.mark ) {
26 | if ( props.mark[ 0 ] ) styles += ';top:' + props.mark[ 0 ]
27 | if ( props.mark[ 1 ] ) styles += ';bottom:' + props.mark[ 1 ]
28 | if ( props.mark[ 2 ] ) styles += ';left:' + props.mark[ 2 ]
29 | if ( props.mark[ 3 ] ) styles += ';right:' + props.mark[ 3 ]
30 | }
31 |
32 | styles += ';background:' + props.bgColor
33 |
34 | return styles
35 | }
36 |
37 | module.exports = {
38 | formatName: formatName,
39 | getDialogStyles: getDialogStyles,
40 | getMarkStyles: getMarkStyles
41 | }
--------------------------------------------------------------------------------
/miniprogram/components/Popover/package.json:
--------------------------------------------------------------------------------
1 | {
2 | "name": "@lightd/popover",
3 | "cname":"弹框",
4 | "version": "1.0.0",
5 | "main": "index.js",
6 | "homepage": "https://github.com/MatrixAges/light-design/tree/master/miniprogram/components/Popover",
7 | "author": "Matrixage",
8 | "license": "MIT"
9 | }
--------------------------------------------------------------------------------
/miniprogram/components/Popover/readme.md:
--------------------------------------------------------------------------------
1 |
2 |
3 | 弹框的灵感来源与微信的右上角点击弹框,她提供一个固定在页面上的局部列表内容选项,比 ActionSheet 更有辨识度。
4 |
5 | 使用场景
6 |
7 | - 应用扩展功能的交互展示。
8 | - 展示一些其他面板选项。
9 |
10 |
11 |
12 | | 属性 | 说明 | 类型 | 默认值 | 必填 | 版本 |
13 | | - | - | - | - | - | - |
14 | | visible | 是否可见 | boolean | false | 否 | 1.0.0 |
15 | | list | 数据项 | IList | [] | 是 | 1.0.0 |
16 | | position | 弹出位置 | [string, string, string, string] | [ '', '', '', '' ] | 否 | 1.0.0 |
17 | | mark | 标记位置 | [string, string, string, string] | [ '-8rpx', '', '', '30rpx' ] | 否 | 1.0.0 |
18 | | transformOrigin | 动画原点 | string | 'top right' | 否 | 1.0.0 |
19 | | bgColor | 背景 | string | 'black' | 否 | 1.0.0 |
20 | | color | 颜色 | string | 'white' | 否 | 1.0.0 |
21 | | divideColor | 分割线颜色 | string | 'rgba(255, 255, 255, 0.15)' | 否 | 1.0.0 |
22 | | zIndex | 层级 | number | 100 | 否 | 1.0.0 |
23 |
24 | 默认效果
25 |
26 | ```html
27 |
32 |
33 | ```
34 |
35 | 设定位置
36 |
37 | ```html
38 |
43 |
44 | ```
45 |
46 | 设定标记
47 |
48 | ```html
49 |
55 |
56 | ```
57 |
58 | 动画原点
59 |
60 | ```html
61 |
68 |
69 | ```
70 |
71 | 自定义颜色
72 |
73 | ```html
74 |
82 |
83 | ```
--------------------------------------------------------------------------------
/miniprogram/components/Ripple/index.json:
--------------------------------------------------------------------------------
1 | {
2 | "component": true,
3 | "usingComponents": {}
4 | }
--------------------------------------------------------------------------------
/miniprogram/components/Ripple/index.less:
--------------------------------------------------------------------------------
1 | .content_wrap {
2 | position: relative;
3 | display: flex;
4 | margin: 0;
5 | padding: 0;
6 | background-color: transparent;
7 |
8 | .ripple_wrap {
9 | position: absolute;
10 | top: 0;
11 | left: 0;
12 | z-index: 1;
13 | overflow: hidden;
14 | box-sizing: border-box;
15 | width: 100%;
16 | height: 100%;
17 |
18 | .ripple {
19 | position: absolute;
20 | top: -100%;
21 | left: -100%;
22 | width: 36px;
23 | height: 36px;
24 | border-radius: 50%;
25 | transition-timing-function: ease-in;
26 | transition-property: opacity, transform;
27 | transform: translate(-50%, -50%);
28 | }
29 | }
30 |
31 | .content {
32 | background-position: center;
33 | }
34 | }
--------------------------------------------------------------------------------
/miniprogram/components/Ripple/index.wxml:
--------------------------------------------------------------------------------
1 |
8 |
13 |
17 |
18 |
19 |
20 |
21 |
--------------------------------------------------------------------------------
/miniprogram/components/Ripple/package.json:
--------------------------------------------------------------------------------
1 | {
2 | "name": "@lightd/ripple",
3 | "cname":"水波纹",
4 | "version": "1.0.0",
5 | "main": "index.js",
6 | "homepage": "https://github.com/MatrixAges/light-design/tree/master/miniprogram/components/Ripple",
7 | "author": "Matrixage",
8 | "license": "MIT"
9 | }
--------------------------------------------------------------------------------
/miniprogram/components/Ripple/readme.md:
--------------------------------------------------------------------------------
1 |
2 |
3 | 水波纹组件来源于 Google 的 Material Design,她作为原子化元素能够包裹任何其他子元素,提供如水波纹般的点击和触摸交互效果。
4 |
5 | 使用场景
6 |
7 | - 应用与按钮之上。
8 | - 用于展示卡片点击效果反馈。
9 |
10 |
11 |
12 | | 属性 | 说明 | 类型 | 默认值 | 必填 | 版本 |
13 | | - | - | - | - | - | - |
14 | | color | 颜色 | string | 'rgba(0, 0, 0, 0.2)' | 否 | 1.0.0 |
15 | | radius | 圆角 | number | 8 | 否 | 1.0.0 |
16 |
17 | 默认效果
18 |
19 | ```html
20 |
21 |
22 |
23 | ```
24 |
25 | 设定颜色
26 |
27 | ```html
28 |
29 |
30 |
31 | ```
32 |
33 | 绑定方法
34 |
35 | ```html
36 |
37 |
41 |
42 | ```
43 |
44 | 设定圆角
45 |
46 | ```html
47 |
48 |
52 |
53 | ```
54 |
55 | 幽灵按钮
56 |
57 | ```html
58 |
59 |
60 |
61 | ```
62 |
63 | 任意使用
64 |
65 | ```html
66 |
67 |
74 | Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod
75 | tempor
76 | incididunt
77 | ut labore et dolore magna aliqua.
78 |
79 |
80 | ```
--------------------------------------------------------------------------------
/miniprogram/components/SnackBar/index.json:
--------------------------------------------------------------------------------
1 | {
2 | "component": true,
3 | "usingComponents": {}
4 | }
--------------------------------------------------------------------------------
/miniprogram/components/SnackBar/index.wxml:
--------------------------------------------------------------------------------
1 |
5 |
6 |
12 |
16 |
20 |
24 | {{title}}
25 | {{description}}{{slot}}
29 |
30 |
31 |
35 |
39 |
40 |
41 |
42 |
--------------------------------------------------------------------------------
/miniprogram/components/SnackBar/index.wxs:
--------------------------------------------------------------------------------
1 | function formatName( name ) {
2 | return name.substring( 0, 5 )
3 | }
4 |
5 | function getContentStyles( props ) {
6 | var styles = ''
7 |
8 | if ( props.cover ) styles += ';border-radius:0'
9 | if ( props.color ) styles += ';color:' + props.color
10 | if ( props.bgColor ) styles += ';background:' + props.bgColor
11 |
12 | return styles
13 | }
14 |
15 | module.exports = {
16 | formatName: formatName,
17 | getContentStyles: getContentStyles
18 | }
--------------------------------------------------------------------------------
/miniprogram/components/SnackBar/package.json:
--------------------------------------------------------------------------------
1 | {
2 | "name": "@lightd/snackbar",
3 | "cname":"提示栏",
4 | "version": "1.0.0",
5 | "main": "index.js",
6 | "homepage": "https://github.com/MatrixAges/light-design/tree/master/miniprogram/components/SnackBar",
7 | "author": "Matrixage",
8 | "license": "MIT"
9 | }
--------------------------------------------------------------------------------
/miniprogram/components/Sticky/index.json:
--------------------------------------------------------------------------------
1 | {
2 | "component": true,
3 | "usingComponents": {}
4 | }
--------------------------------------------------------------------------------
/miniprogram/components/Sticky/index.less:
--------------------------------------------------------------------------------
1 | .sticky_wrap {
2 | position: relative;
3 |
4 | .fixed {
5 | position: fixed;
6 | top: 0;
7 | }
8 | }
--------------------------------------------------------------------------------
/miniprogram/components/Sticky/index.wxml:
--------------------------------------------------------------------------------
1 |
5 |
6 |
11 |
15 |
16 |
17 |
--------------------------------------------------------------------------------
/miniprogram/components/Sticky/index.wxs:
--------------------------------------------------------------------------------
1 | function getWrapStyles( props ) {
2 | var styles = ''
3 |
4 | if ( props.fixed ) {
5 | styles += ';height:' + props.height + 'px'
6 | styles += ';z-index:' + props.zIndex
7 | }
8 |
9 | if ( props.disabled ) styles += ';position:unset'
10 |
11 | return styles
12 | }
13 |
14 | function getContentStyles( props ) {
15 | var styles = ''
16 |
17 | if ( props.fixed ) {
18 | styles += ';width:' + props.width + 'px'
19 | styles += ';top:' + props.offsetTop + 'px'
20 | }
21 |
22 | return styles
23 | }
24 |
25 | module.exports = {
26 | getWrapStyles: getWrapStyles,
27 | getContentStyles: getContentStyles
28 | }
--------------------------------------------------------------------------------
/miniprogram/components/Sticky/package.json:
--------------------------------------------------------------------------------
1 | {
2 | "name": "@lightd/sticky",
3 | "cname":"粘性布局",
4 | "version": "1.0.0",
5 | "main": "index.js",
6 | "homepage": "https://github.com/MatrixAges/light-design/tree/master/miniprogram/components/Sticky",
7 | "author": "Matrixage",
8 | "license": "MIT"
9 | }
--------------------------------------------------------------------------------
/miniprogram/components/Sticky/readme.md:
--------------------------------------------------------------------------------
1 |
2 |
3 | 粘性布局来源于css中的 position:sticky 属性,由于小程序浏览器内核的原因,该特性需要通过组件的形式来实现。
4 |
5 | 使用场景
6 |
7 | - 当页面滚动时,将tabbar悬浮显示在页面顶部。
8 | - 页面有长的 table 时,滚动页面,表头悬浮显示在页面顶部,获得更好的信息展示效果。
9 |
10 |
11 |
12 | | 属性 | 说明 | 类型 | 默认值 | 必填 | 版本 |
13 | | - | - | - | - | - | - |
14 | | offsetTop | 顶部距离 | number | 0 | 否 | 1.0.0 |
15 | | zIndex | 层级 | number | 100 | 否 | 1.0.0 |
16 | | container | 容器 | string | '' | 否 | 1.0.0 |
17 | | disabled | 禁用 | boolean | false | 否 | 1.0.0 |
18 |
19 | 默认效果
20 |
21 | ```html
22 |
23 |
24 |
25 | ```
26 |
27 | 顶部距离
28 |
29 | ```html
30 |
31 |
32 |
33 | ```
34 |
35 | 指定容器
36 |
37 | ```html
38 |
43 |
44 |
48 |
55 | Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor
56 | incididunt
57 | ut labore et dolore magna aliqua.
58 |
59 |
60 |
61 |
62 | ```
--------------------------------------------------------------------------------
/miniprogram/components/Tab/Sticky/index.json:
--------------------------------------------------------------------------------
1 | {
2 | "component": true,
3 | "usingComponents": {}
4 | }
--------------------------------------------------------------------------------
/miniprogram/components/Tab/Sticky/index.less:
--------------------------------------------------------------------------------
1 | .sticky_wrap {
2 | position: relative;
3 |
4 | .fixed {
5 | position: fixed;
6 | top: 0;
7 | }
8 | }
--------------------------------------------------------------------------------
/miniprogram/components/Tab/Sticky/index.wxml:
--------------------------------------------------------------------------------
1 |
5 |
6 |
11 |
15 |
16 |
17 |
--------------------------------------------------------------------------------
/miniprogram/components/Tab/Sticky/index.wxs:
--------------------------------------------------------------------------------
1 | function getWrapStyles( props ) {
2 | var styles = ''
3 |
4 | if ( props.fixed ) {
5 | styles += ';height:' + props.height + 'px'
6 | styles += ';z-index:' + props.zIndex
7 | }
8 |
9 | if ( props.disabled ) styles += ';position:unset'
10 |
11 | return styles
12 | }
13 |
14 | function getContentStyles( props ) {
15 | var styles = ''
16 |
17 | if ( props.fixed ) {
18 | styles += ';width:' + props.width + 'px'
19 | styles += ';top:' + props.offsetTop + 'px'
20 | }
21 |
22 | return styles
23 | }
24 |
25 | module.exports = {
26 | getWrapStyles: getWrapStyles,
27 | getContentStyles: getContentStyles
28 | }
--------------------------------------------------------------------------------
/miniprogram/components/Tab/TabItem/index.json:
--------------------------------------------------------------------------------
1 | {
2 | "component": true,
3 | "usingComponents": {}
4 | }
--------------------------------------------------------------------------------
/miniprogram/components/Tab/TabItem/index.less:
--------------------------------------------------------------------------------
1 | .init {
2 | color: black;
3 | font-size: 30rpx;
4 | line-height: 1.6;
5 | }
6 |
7 | :host {
8 | display: flex;
9 | flex: 1;
10 | flex-shrink: 0;
11 | box-sizing: border-box;
12 |
13 | .init();
14 | }
15 |
16 | .tab_item {
17 | width: 100%;
18 | }
--------------------------------------------------------------------------------
/miniprogram/components/Tab/TabItem/index.ts:
--------------------------------------------------------------------------------
1 | // @ts-nocheck
2 |
3 | const Tab = '../index'
4 |
5 | Component({
6 | relations: {
7 | [ Tab ]: { type: 'parent' }
8 | },
9 | properties: {
10 | title: String,
11 | disabled: Boolean
12 | },
13 | data: {
14 | current: null,
15 | index: null,
16 | rendered: false
17 | },
18 | tab: {} as WechatMiniprogram.Component.TrivialInstance,
19 | methods: {
20 | reset() {
21 | this.setData({
22 | current: null,
23 | index: null,
24 | rendered: false
25 | })
26 | },
27 | updateCurrent() {
28 | const { index, rendered } = this.data
29 | const { current, persist, lazyload } = this.tab.__data__
30 |
31 | if (persist && rendered) {
32 | this.setData({ current })
33 | } else {
34 | this.setData({
35 | current,
36 | rendered: index ? index === current : true
37 | })
38 | }
39 | }
40 | },
41 | lifetimes: {
42 | ready() {
43 | const tab = this.getRelationNodes(Tab)[ 0 ]
44 | const { titles, lazyload } = tab.__data__
45 | const index = titles.findIndex((item: { text: string, disabled: boolean }) => item.text === this.data.title)
46 |
47 | this.tab = tab
48 |
49 | this.setData({ index })
50 |
51 | if (lazyload) {
52 | this.updateCurrent()
53 | } else {
54 | this.setData({ rendered: true })
55 | }
56 | }
57 | }
58 | })
59 |
--------------------------------------------------------------------------------
/miniprogram/components/Tab/TabItem/index.wxml:
--------------------------------------------------------------------------------
1 |
2 |
3 |
--------------------------------------------------------------------------------
/miniprogram/components/Tab/behavior.ts:
--------------------------------------------------------------------------------
1 | // @ts-nocheck
2 |
3 | const Index = Behavior( {
4 | x: 0,
5 | offset_x: 0,
6 | next: null,
7 | methods: {
8 | reset () {
9 | this.x = 0
10 | this.offset_x = 0
11 | this.next = null
12 | },
13 | touchStart ( e: WechatMiniprogram.TouchEvent ) {
14 | this.reset()
15 |
16 | this.x = e.touches[ 0 ].clientX
17 | },
18 | touchMove ( e: WechatMiniprogram.TouchEvent ) {
19 | this.offset_x = e.touches[ 0 ].clientX - this.x
20 | }
21 | }
22 | } )
23 |
24 | export default Index
--------------------------------------------------------------------------------
/miniprogram/components/Tab/index.json:
--------------------------------------------------------------------------------
1 | {
2 | "component": true,
3 | "usingComponents": {
4 | "local-sticky":"./Sticky/index"
5 | }
6 | }
--------------------------------------------------------------------------------
/miniprogram/components/Tab/index.wxml:
--------------------------------------------------------------------------------
1 |
5 |
6 |
11 |
15 |
21 |
33 |
37 |
42 | {{item.text}}
50 |
51 |
52 |
53 |
58 |
66 |
67 |
68 |
69 |
--------------------------------------------------------------------------------
/miniprogram/components/Tab/index.wxs:
--------------------------------------------------------------------------------
1 | function px( str ) {
2 | return str + 'px'
3 | }
4 |
5 | function calc( str ) {
6 | return 'calc(' + str + ')'
7 | }
8 |
9 | function add( a, b ) {
10 | return a + ' + ' + b
11 | }
12 |
13 | function reduce( a, b ) {
14 | return a + ' - ' + b
15 | }
16 |
17 | function getStylesOfActiveLine( props ) {
18 | var styles = ''
19 |
20 | if ( !props.bar_items.length ) return ''
21 |
22 | function getSize( param ) {
23 | return ';' + param + ':' + calc(
24 | reduce(
25 | px( props.bar_items[ props.current ][ param ] ),
26 | '48rpx'
27 | )
28 | )
29 | }
30 |
31 | function getPosition( param ) {
32 | return ';' + param + ':' + calc(
33 | add(
34 | reduce(
35 | px( props.bar_items[ props.current ][ param ] ),
36 | px( props.bar_items[ 0 ][ param ] )
37 | ),
38 | '24rpx'
39 | )
40 | )
41 | }
42 |
43 | if ( !props.vertical ) {
44 | styles += getSize( 'width' )
45 | styles += getPosition( 'left' )
46 | } else {
47 | styles += getSize( 'height' )
48 | styles += getPosition( 'top' )
49 | }
50 |
51 | return styles
52 | }
53 |
54 | function getStylesOfContentWrap( props ) {
55 | var styles = ''
56 |
57 | if ( !props.vertical ) {
58 | if ( props.titles.length ) styles += ';width:' + 100 * props.titles.length + '%'
59 | if ( !props.titles.length ) styles += ';width:' + 1000 + '%'
60 |
61 | styles += ';transform:translateX(-' + props.current * 100 / props.titles.length + '%)'
62 | } else {
63 | if ( props.titles.length ) styles += ';height:' + 100 * props.titles.length + '%'
64 | if ( !props.titles.length ) styles += ';height:' + 1000 + '%'
65 |
66 | styles += ';transform:translateY(-' + props.current * 100 / props.titles.length + '%)'
67 | }
68 |
69 | return styles
70 | }
71 |
72 | module.exports = {
73 | getStylesOfActiveLine: getStylesOfActiveLine,
74 | getStylesOfContentWrap: getStylesOfContentWrap
75 | }
--------------------------------------------------------------------------------
/miniprogram/components/Tab/package.json:
--------------------------------------------------------------------------------
1 | {
2 | "name": "@lightd/tab",
3 | "cname":"选项卡",
4 | "version": "1.0.0",
5 | "main": "index.js",
6 | "homepage": "https://github.com/MatrixAges/light-design/tree/master/miniprogram/components/Tab",
7 | "author": "Matrixage",
8 | "license": "MIT"
9 | }
--------------------------------------------------------------------------------
/miniprogram/components/Text/index.json:
--------------------------------------------------------------------------------
1 | {
2 | "component": true,
3 | "usingComponents": {}
4 | }
--------------------------------------------------------------------------------
/miniprogram/components/Text/index.less:
--------------------------------------------------------------------------------
1 | @color_success: #81C784;
2 | @color_warning: #FFB74D;
3 | @color_error: #E57373;
4 |
5 | .init {
6 | color: black;
7 | font-size: 30rpx;
8 | line-height: 1.6;
9 | }
10 |
11 | .text_wrap {
12 | .init();
13 |
14 | &.p {
15 | display: inline-block;
16 | margin: 16rpx 0;
17 | line-height: 1.8;
18 | }
19 |
20 | &.b {
21 | font-weight: bold;
22 | }
23 |
24 | &.i {
25 | font-style: italic;
26 | }
27 |
28 | &.del {
29 | text-decoration: line-through;
30 | }
31 |
32 | &.h7 {
33 | font-size: 0.6em;
34 | }
35 |
36 | &.h6 {
37 | font-size: 0.8em;
38 | }
39 |
40 | &.h5 {
41 | font-size: 1em;
42 | }
43 |
44 | &.h4 {
45 | font-size: 1.2em;
46 | }
47 |
48 | &.h3 {
49 | font-size: 1.5em;
50 | }
51 |
52 | &.h2 {
53 | font-size: 1.8em;
54 | }
55 |
56 | &.h1 {
57 | font-size: 2.1em;
58 | }
59 |
60 | &.quote {
61 | box-sizing: border-box;
62 | padding: 24rpx;
63 | background-color: whitesmoke;
64 | color: #888;
65 | font-size: 0.9em;
66 | }
67 |
68 | &.success {
69 | color: @color_success;
70 | }
71 |
72 | &.warning {
73 | color: @color_warning;
74 | }
75 |
76 | &.error {
77 | color: @color_error;
78 | }
79 |
80 | &.line_clamp_1 {
81 | display: -webkit-box;
82 | overflow: hidden;
83 | -webkit-box-orient: vertical;
84 |
85 | -webkit-line-clamp: 1
86 | }
87 |
88 | &.line_clamp_2 {
89 | display: -webkit-box;
90 | overflow: hidden;
91 | -webkit-box-orient: vertical;
92 |
93 | -webkit-line-clamp: 2
94 | }
95 |
96 | &.line_clamp_3 {
97 | display: -webkit-box;
98 | overflow: hidden;
99 | -webkit-box-orient: vertical;
100 |
101 | -webkit-line-clamp: 3
102 | }
103 |
104 | &.line_clamp_4 {
105 | display: -webkit-box;
106 | overflow: hidden;
107 | -webkit-box-orient: vertical;
108 |
109 | -webkit-line-clamp: 4
110 | }
111 |
112 | &.line_clamp_5 {
113 | display: -webkit-box;
114 | overflow: hidden;
115 | -webkit-box-orient: vertical;
116 |
117 | -webkit-line-clamp: 5
118 | }
119 | }
--------------------------------------------------------------------------------
/miniprogram/components/Text/index.ts:
--------------------------------------------------------------------------------
1 | Component( {
2 | properties: {
3 | p: Boolean,
4 | b: Boolean,
5 | i: Boolean,
6 | del: Boolean,
7 | h1: Boolean,
8 | h2: Boolean,
9 | h3: Boolean,
10 | h4: Boolean,
11 | h5: Boolean,
12 | h6: Boolean,
13 | h7: Boolean,
14 | quote: Boolean,
15 | success: Boolean,
16 | warning: Boolean,
17 | error: Boolean,
18 | color: String,
19 | fontSize: String,
20 | textAlign: String,
21 | style: String,
22 | lineClamp: Number
23 | }
24 | } )
25 |
--------------------------------------------------------------------------------
/miniprogram/components/Text/index.wxml:
--------------------------------------------------------------------------------
1 |
5 |
6 |
10 |
11 |
--------------------------------------------------------------------------------
/miniprogram/components/Text/index.wxs:
--------------------------------------------------------------------------------
1 | function getClasses( props ) {
2 | var classes = ''
3 |
4 | if ( props.p ) classes += ' p'
5 | if ( props.b ) classes += ' b'
6 | if ( props.i ) classes += ' i'
7 | if ( props.del ) classes += ' del'
8 | if ( props.h1 ) classes += ' h1'
9 | if ( props.h2 ) classes += ' h2'
10 | if ( props.h3 ) classes += ' h3'
11 | if ( props.h4 ) classes += ' h4'
12 | if ( props.h5 ) classes += ' h5'
13 | if ( props.h6 ) classes += ' h6'
14 | if ( props.h7 ) classes += ' h7'
15 | if ( props.quote ) classes += ' quote'
16 | if ( props.success ) classes += ' success'
17 | if ( props.warning ) classes += ' warning'
18 | if ( props.error ) classes += ' error'
19 | if ( props.lineClamp ) classes += ' line_clamp_' + props.lineClamp
20 |
21 | return classes
22 | }
23 |
24 | function getStyles( props ) {
25 | var styles = ''
26 |
27 | if ( props.color ) styles += ';color:' + props.color
28 | if ( props.fontSize ) styles += ';font-size:' + props.fontSize
29 | if ( props.textAlign ) styles += ';text-align:' + props.textAlign
30 |
31 | return styles
32 | }
33 |
34 | module.exports = {
35 | getClasses: getClasses,
36 | getStyles: getStyles
37 | }
--------------------------------------------------------------------------------
/miniprogram/components/Text/package.json:
--------------------------------------------------------------------------------
1 | {
2 | "name": "@lightd/text",
3 | "cname":"文字",
4 | "version": "1.0.0",
5 | "main": "index.js",
6 | "homepage": "https://github.com/MatrixAges/light-design/tree/master/miniprogram/components/Text",
7 | "author": "Matrixage",
8 | "license": "MIT"
9 | }
--------------------------------------------------------------------------------
/miniprogram/components/Toast/index.json:
--------------------------------------------------------------------------------
1 | {
2 | "component": true,
3 | "usingComponents": {}
4 | }
--------------------------------------------------------------------------------
/miniprogram/components/Toast/index.wxml:
--------------------------------------------------------------------------------
1 |
7 |
11 |
16 |
20 | {{title}}
21 |
22 |
23 |
--------------------------------------------------------------------------------
/miniprogram/components/Toast/package.json:
--------------------------------------------------------------------------------
1 | {
2 | "name": "@lightd/toast",
3 | "cname":"消息提示",
4 | "version": "1.0.0",
5 | "main": "index.js",
6 | "homepage": "https://github.com/MatrixAges/light-design/tree/master/miniprogram/components/Toast",
7 | "author": "Matrixage",
8 | "license": "MIT"
9 | }
--------------------------------------------------------------------------------
/miniprogram/components/Toast/readme.md:
--------------------------------------------------------------------------------
1 |
2 |
3 | 消息提示是一种轻量的内容提示组件,由一个状态图标和文字内容组成。
4 |
5 | 使用场景
6 |
7 | - 展示按钮点击之后触发的信息反馈。
8 | - 展示应用运行时的错误信息。
9 |
10 |
11 |
12 | | 属性 | 说明 | 类型 | 默认值 | 必填 | 版本 |
13 | | - | - | - | - | - | - |
14 | | visible | 是否可见 | boolean | false | 否 | 1.0.0 |
15 | | position | 位置 | 'top' or 'bottom' | 'bottom' | 否 | 1.0.0 |
16 | | type | 类型 | Toast_type | '' | 否 | 1.0.0 |
17 | | useColor | 背景色 | boolean | false | 否 | 1.0.0 |
18 | | color | 颜色 | string | '' | 否 | 1.0.0 |
19 | | bgColor | 背景颜色 | string | '' | 否 | 1.0.0 |
20 | | title | 标题 | string | '' | 否 | 1.0.0 |
21 | | duration | 关闭时间 | number | 3000 | 否 | 1.0.0 |
22 | | zIndex | 层级 | number | 100 | 否 | 1.0.0 |
23 |
24 | types
25 |
26 | ```typescript
27 | type Toast_type = '' | 'success' | 'warning' | 'error'
28 | ```
29 |
30 | 默认效果
31 |
32 | ```html
33 |
37 | ```
38 |
39 | 顶部弹出
40 |
41 | ```html
42 |
47 | ```
48 |
49 | 自定义颜色
50 |
51 | ```html
52 |
58 | ```
59 |
60 | 关闭时间
61 |
62 | ```html
63 |
68 | ```
69 |
70 | 设定类型
71 |
72 | ```html
73 |
78 |
83 |
88 | ```
89 |
90 | 背景色
91 |
92 | ```html
93 |
99 |
105 |
111 | ```
--------------------------------------------------------------------------------
/miniprogram/image/icon_add_person.svg:
--------------------------------------------------------------------------------
1 |
--------------------------------------------------------------------------------
/miniprogram/image/icon_add_person_black.svg:
--------------------------------------------------------------------------------
1 |
--------------------------------------------------------------------------------
/miniprogram/image/icon_chat.svg:
--------------------------------------------------------------------------------
1 |
--------------------------------------------------------------------------------
/miniprogram/image/icon_chat_black.svg:
--------------------------------------------------------------------------------
1 |
--------------------------------------------------------------------------------
/miniprogram/image/icon_close.svg:
--------------------------------------------------------------------------------
1 |
--------------------------------------------------------------------------------
/miniprogram/image/icon_feedback.svg:
--------------------------------------------------------------------------------
1 |
--------------------------------------------------------------------------------
/miniprogram/image/icon_feedback_black.svg:
--------------------------------------------------------------------------------
1 |
--------------------------------------------------------------------------------
/miniprogram/image/icon_info.svg:
--------------------------------------------------------------------------------
1 |
--------------------------------------------------------------------------------
/miniprogram/image/icon_pay.svg:
--------------------------------------------------------------------------------
1 |
--------------------------------------------------------------------------------
/miniprogram/image/icon_pay_black.svg:
--------------------------------------------------------------------------------
1 |
--------------------------------------------------------------------------------
/miniprogram/image/icon_right.svg:
--------------------------------------------------------------------------------
1 |
--------------------------------------------------------------------------------
/miniprogram/image/icon_scan.svg:
--------------------------------------------------------------------------------
1 |
--------------------------------------------------------------------------------
/miniprogram/image/icon_scan_black.svg:
--------------------------------------------------------------------------------
1 |
--------------------------------------------------------------------------------
/miniprogram/image/logo_dingding.svg:
--------------------------------------------------------------------------------
1 |
--------------------------------------------------------------------------------
/miniprogram/image/logo_instagram.svg:
--------------------------------------------------------------------------------
1 |
--------------------------------------------------------------------------------
/miniprogram/image/logo_pengyouquan.svg:
--------------------------------------------------------------------------------
1 |
--------------------------------------------------------------------------------
/miniprogram/image/logo_qq.svg:
--------------------------------------------------------------------------------
1 |
--------------------------------------------------------------------------------
/miniprogram/image/logo_qzone.svg:
--------------------------------------------------------------------------------
1 |
--------------------------------------------------------------------------------
/miniprogram/image/logo_wechat.svg:
--------------------------------------------------------------------------------
1 |
--------------------------------------------------------------------------------
/miniprogram/image/logo_weibo.svg:
--------------------------------------------------------------------------------
1 |
--------------------------------------------------------------------------------
/miniprogram/image/logo_yixin.svg:
--------------------------------------------------------------------------------
1 |
--------------------------------------------------------------------------------
/miniprogram/image/logo_zhihu.svg:
--------------------------------------------------------------------------------
1 |
--------------------------------------------------------------------------------
/miniprogram/page_components/_Tips/index.json:
--------------------------------------------------------------------------------
1 | {
2 | "component": true,
3 | "usingComponents": {}
4 | }
--------------------------------------------------------------------------------
/miniprogram/page_components/_Tips/index.less:
--------------------------------------------------------------------------------
1 | .tips_wrap {
2 | @width_left: 72rpx;
3 |
4 | position: relative;
5 | display: flex;
6 | width: 100%;
7 | box-sizing: border-box;
8 | padding: 32rpx 36rpx;
9 | padding-left: @width_left;
10 | text-align: justify;
11 | box-shadow: var(--box_shadow_morphic);
12 |
13 | &.topBorder{
14 | box-shadow: none;
15 | border-top: 2rpx solid var(--color_border);
16 | }
17 |
18 | .icon_info {
19 | position: absolute;
20 | top: 36rpx;
21 | left: 24rpx;
22 | width: 32rpx;
23 | height: 32rpx;
24 | }
25 |
26 | .text {
27 | font-size: 26rpx;
28 | }
29 | }
--------------------------------------------------------------------------------
/miniprogram/page_components/_Tips/index.ts:
--------------------------------------------------------------------------------
1 | Component({
2 | properties: {
3 | text: {
4 | type: String,
5 | value: ''
6 | },
7 | topBorder: {
8 | type: Boolean,
9 | value: false
10 | }
11 | }
12 | })
13 |
--------------------------------------------------------------------------------
/miniprogram/page_components/_Tips/index.wxml:
--------------------------------------------------------------------------------
1 |
2 |
7 | {{text}}
8 |
--------------------------------------------------------------------------------
/miniprogram/pages/ActionSheet/index.json:
--------------------------------------------------------------------------------
1 | {
2 | "navigationBarTitleText": "ActionSheet"
3 | }
--------------------------------------------------------------------------------
/miniprogram/pages/ActionSheet/index.less:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/MatrixAges/light-design/63031aa4a62c0ceda8802ad5c186778b637e45ff/miniprogram/pages/ActionSheet/index.less
--------------------------------------------------------------------------------
/miniprogram/pages/Button/index.json:
--------------------------------------------------------------------------------
1 | {
2 | "navigationBarTitleText": "Button"
3 | }
--------------------------------------------------------------------------------
/miniprogram/pages/Button/index.less:
--------------------------------------------------------------------------------
1 | .example{
2 | padding: 12rpx;
3 | }
--------------------------------------------------------------------------------
/miniprogram/pages/Button/index.ts:
--------------------------------------------------------------------------------
1 | Page({})
--------------------------------------------------------------------------------
/miniprogram/pages/Card/index.json:
--------------------------------------------------------------------------------
1 | {
2 | "navigationBarTitleText": "Card"
3 | }
--------------------------------------------------------------------------------
/miniprogram/pages/Card/index.less:
--------------------------------------------------------------------------------
1 | .example_items{
2 | .example_item{
3 | flex-direction: column !important;
4 |
5 | .title_wrap{
6 | margin-bottom: 24rpx!important;
7 | }
8 | }
9 | }
--------------------------------------------------------------------------------
/miniprogram/pages/Card/index.ts:
--------------------------------------------------------------------------------
1 | Page({})
--------------------------------------------------------------------------------
/miniprogram/pages/Card/index.wxml:
--------------------------------------------------------------------------------
1 |
2 |
3 |
4 | 默认效果
5 | default
6 |
7 |
8 |
9 |
16 | 南山经之首曰䧿山。其首曰招摇之山,临于西海之上,多桂,多金玉。有草焉,其状如韭而青华,其名曰祝馀,食之不饥。有木焉,其状如榖而黑理,其华四照。其名曰迷榖,佩之不迷。有兽焉,其状如禺而白耳,伏行人走,其名曰狌狌,食之善走。丽麂之水出焉,而西流注于海,其中多育沛,佩之无瘕疾。
17 |
18 |
19 |
20 |
21 |
22 |
23 | 设置样式
24 | custom
25 |
26 |
27 |
28 |
38 | 西山经华山之首,曰钱来之山,其上多松,其下多洗石。有兽焉,其状如羊而马尾,名曰羬羊,其脂可以已腊。
40 | 西四十五里,曰松果之山。濩水出焉,北流注于渭,其中多铜。有鸟焉,其名曰䳋渠,其状如山鸡,黑身赤足,可以已[月暴]。
42 | 又西六十里,曰太华之山,削成而四方,其高五千仞,其广十里,鸟兽莫居。有蛇焉,名曰肥(虫遗),六足四翼,见则天下大旱。
43 |
44 |
45 |
46 |
47 |
48 |
49 | 悬浮阴影
50 | shadow
51 |
52 |
53 |
54 |
61 | 《中山经》薄山之首,曰甘枣之山。共水出焉,而西流注于河。其上多杻木,其下有草焉,葵本而杏叶,黄华而荚实,名曰箨,可以已懵。有兽焉,其状如囗鼠而文题,其名曰㔮,食之已瘿。
62 |
63 |
64 |
65 |
66 |
--------------------------------------------------------------------------------
/miniprogram/pages/Dialog/index.json:
--------------------------------------------------------------------------------
1 | {
2 | "navigationBarTitleText": "Dialog"
3 | }
--------------------------------------------------------------------------------
/miniprogram/pages/Dialog/index.less:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/MatrixAges/light-design/63031aa4a62c0ceda8802ad5c186778b637e45ff/miniprogram/pages/Dialog/index.less
--------------------------------------------------------------------------------
/miniprogram/pages/Dialog/index.ts:
--------------------------------------------------------------------------------
1 | import { blockRight } from 'components/Icon/data'
2 |
3 | Page({
4 | data: {
5 | blockRight: blockRight,
6 | visible_default: false
7 | },
8 | onOption (e: any) {
9 | const _that = this
10 | const { mark: { type } } = e
11 |
12 | if (!type) return
13 |
14 | _that.setData({
15 | [`visible_${type}`]: true
16 | })
17 | }
18 | })
19 |
--------------------------------------------------------------------------------
/miniprogram/pages/DialogQueue/index.json:
--------------------------------------------------------------------------------
1 | {
2 | "navigationBarTitleText": "DialogQueue"
3 | }
--------------------------------------------------------------------------------
/miniprogram/pages/DialogQueue/index.less:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/MatrixAges/light-design/63031aa4a62c0ceda8802ad5c186778b637e45ff/miniprogram/pages/DialogQueue/index.less
--------------------------------------------------------------------------------
/miniprogram/pages/DialogQueue/index.ts:
--------------------------------------------------------------------------------
1 | import { blockRight } from 'components/Icon/data'
2 |
3 | Page({
4 | data: {
5 | blockRight: blockRight,
6 | visible_default: false,
7 | list: [
8 | {
9 | rank: 100,
10 | title: '夜间海报',
11 | imgSrc:
12 | 'https://cdn.pixabay.com/photo/2020/05/19/06/30/sun-5189430_1280.jpg',
13 | url: '',
14 | daily: true,
15 | durations: [
16 | {
17 | startTime: '00:00:00',
18 | endTime: '23:59:59'
19 | }
20 | ]
21 | },
22 | {
23 | rank: 6,
24 | title: '短信活动',
25 | imgSrc:
26 | 'https://cdn.pixabay.com/photo/2020/02/25/19/16/stawberry-4879794_1280.jpg',
27 | url: '',
28 | daily: true,
29 | durations: [
30 | {
31 | startTime: '00:00:00',
32 | endTime: '23:59:59'
33 | }
34 | ]
35 | },
36 | {
37 | rank: 1,
38 | title: '抽奖活动',
39 | imgSrc:
40 | 'https://cdn.pixabay.com/photo/2014/12/17/21/35/drop-of-water-571956_1280.jpg',
41 | url: '',
42 | daily: false,
43 | durations: [
44 | {
45 | startTime: '2020/5/25 00:00:00',
46 | endTime: '2020/11/28 23:59:59'
47 | },
48 | {
49 | startTime: '2020/12/25 00:00:00',
50 | endTime: '2020/12/28 23:59:59'
51 | }
52 | ]
53 | },
54 | {
55 | rank: 4,
56 | title: '买100送200',
57 | imgSrc:
58 | 'https://cdn.pixabay.com/photo/2014/11/25/16/32/drop-of-water-545377_1280.jpg',
59 | target: 'miniProgram',
60 | appId: '12312312mdmsadmasqaasdasd',
61 | path: '/pages/goods?id=103',
62 | version: 'develop',
63 | daily: false,
64 | durations: [
65 | {
66 | startTime: '2020/5/25 00:00:00',
67 | endTime: '2020/11/28 23:59:59'
68 | }
69 | ]
70 | }
71 | ]
72 | },
73 | onOption (e: any) {
74 | const _that = this
75 | const { mark: { type } } = e
76 |
77 | if (!type) return
78 |
79 | _that.setData({
80 | [`visible_${type}`]: true
81 | })
82 | }
83 | })
84 |
--------------------------------------------------------------------------------
/miniprogram/pages/DialogQueue/index.wxml:
--------------------------------------------------------------------------------
1 |
2 |
3 |
4 | 默认效果
5 | default
6 |
7 |
17 |
21 |
22 |
--------------------------------------------------------------------------------
/miniprogram/pages/Icon/index.json:
--------------------------------------------------------------------------------
1 | {
2 | "navigationBarTitleText": "Icon"
3 | }
--------------------------------------------------------------------------------
/miniprogram/pages/Icon/index.less:
--------------------------------------------------------------------------------
1 | .example_items {
2 | &.icon_items {
3 | .example_item {
4 | &:hover {
5 | background-color: transparent;
6 | }
7 |
8 | .title_wrap {
9 | flex-direction: column;
10 | align-items: center;
11 | margin-bottom: 12rpx;
12 |
13 | .title {
14 | margin-bottom: 18rpx;
15 | }
16 | }
17 | }
18 | }
19 | }
20 |
21 | .mini_items {
22 | .example_item {
23 | .title_wrap{
24 | align-items: flex-start !important;
25 | }
26 | .examples {
27 | justify-content: center;
28 | .example {
29 | justify-content: flex-end;
30 | }
31 | }
32 | }
33 | }
34 |
35 | .icon_wrap {
36 | position: relative;
37 | display: flex;
38 | justify-content: center;
39 | align-items: center;
40 | width: 100%/4;
41 | padding: 36rpx 0;
42 | box-sizing: border-box;
43 |
44 | &:nth-last-of-type(1),
45 | &:nth-last-of-type(2),
46 | &:nth-last-of-type(3) {
47 | border-bottom: none;
48 | }
49 |
50 | &:hover {
51 | background-color: var(--color_sub_bg);
52 | }
53 |
54 | .icon_name {
55 | font-size: 20rpx;
56 | }
57 | }
--------------------------------------------------------------------------------
/miniprogram/pages/Icon/index.ts:
--------------------------------------------------------------------------------
1 | import data,{ toggle,cube } from 'components/Icon/data'
2 |
3 | type Icon = {
4 | name: string
5 | value: { outline: string; filled: string }
6 | }
7 |
8 | const normal_icons: Array = []
9 | const more_icons: Array = []
10 |
11 | for (const i in data) {
12 | if (!i) break
13 |
14 | //@ts-ignore
15 | if (!data[i].filled) {
16 | normal_icons.push({
17 | name: i,
18 | //@ts-ignore
19 | value: data[i]
20 | })
21 | } else {
22 | more_icons.push({
23 | name: i,
24 | //@ts-ignore
25 | value: data[i]
26 | })
27 | }
28 | }
29 |
30 | Page({
31 | data: {
32 | filled: false,
33 | normal_icons: normal_icons,
34 | more_icons: more_icons,
35 | toggle,
36 | cube
37 | },
38 | onChangeType () {
39 | this.setData({ filled: !this.data.filled })
40 | }
41 | })
42 |
--------------------------------------------------------------------------------
/miniprogram/pages/Landing/index.json:
--------------------------------------------------------------------------------
1 | {
2 | "navigationBarTitleText": "Landing"
3 | }
--------------------------------------------------------------------------------
/miniprogram/pages/Landing/index.less:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/MatrixAges/light-design/63031aa4a62c0ceda8802ad5c186778b637e45ff/miniprogram/pages/Landing/index.less
--------------------------------------------------------------------------------
/miniprogram/pages/Landing/index.ts:
--------------------------------------------------------------------------------
1 | import { blockRight } from 'components/Icon/data'
2 |
3 | Page({
4 | data: {
5 | blockRight:blockRight,visible_default: false
6 | },
7 | onOption (e: any) {
8 | const _that = this
9 | const { mark: { type } } = e
10 |
11 | if (!type) return
12 |
13 | _that.setData({
14 | [`visible_${type}`]: true
15 | })
16 | }
17 | })
18 |
--------------------------------------------------------------------------------
/miniprogram/pages/Landing/index.wxml:
--------------------------------------------------------------------------------
1 |
2 |
3 |
4 | 默认效果
5 | default
6 |
7 |
17 |
18 |
19 |
20 |
21 | 显示遮罩
22 | maskVisible
23 |
24 |
34 |
38 |
39 |
40 |
41 | 遮罩颜色
42 | maskColor
43 |
44 |
54 |
59 |
60 |
--------------------------------------------------------------------------------
/miniprogram/pages/Line/index.json:
--------------------------------------------------------------------------------
1 | {
2 | "navigationBarTitleText": "Line"
3 | }
--------------------------------------------------------------------------------
/miniprogram/pages/Line/index.less:
--------------------------------------------------------------------------------
1 | .mini_items {
2 | .example_item {
3 | .examples {
4 | .example {
5 | justify-content: center;
6 | }
7 | }
8 | }
9 | }
--------------------------------------------------------------------------------
/miniprogram/pages/Line/index.ts:
--------------------------------------------------------------------------------
1 | Page({
2 | click () {
3 | wx.showToast({
4 | icon: 'none',
5 | title: 'clicked'
6 | })
7 | }
8 | })
9 |
--------------------------------------------------------------------------------
/miniprogram/pages/Loading/index.json:
--------------------------------------------------------------------------------
1 | {
2 | "navigationBarTitleText": "Loading"
3 | }
--------------------------------------------------------------------------------
/miniprogram/pages/Loading/index.less:
--------------------------------------------------------------------------------
1 | .examples{
2 | justify-content: center;
3 | }
--------------------------------------------------------------------------------
/miniprogram/pages/Loading/index.ts:
--------------------------------------------------------------------------------
1 | import { blockRight } from 'components/Icon/data'
2 |
3 | Page({
4 | data: {
5 | blockRight:blockRight,visible_default: false
6 | }
7 | })
8 |
--------------------------------------------------------------------------------
/miniprogram/pages/Loading/index.wxml:
--------------------------------------------------------------------------------
1 |
2 |
3 |
4 |
5 |
6 | 默认
7 | refresh
8 |
9 |
10 |
11 |
15 |
16 |
17 |
18 |
19 |
20 | 加载中
21 | loading
22 |
23 |
24 |
25 |
29 |
30 |
31 |
32 |
--------------------------------------------------------------------------------
/miniprogram/pages/Modal/index.json:
--------------------------------------------------------------------------------
1 | {
2 | "navigationBarTitleText": "Modal"
3 | }
--------------------------------------------------------------------------------
/miniprogram/pages/Modal/index.less:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/MatrixAges/light-design/63031aa4a62c0ceda8802ad5c186778b637e45ff/miniprogram/pages/Modal/index.less
--------------------------------------------------------------------------------
/miniprogram/pages/Modal/index.ts:
--------------------------------------------------------------------------------
1 | import { blockRight } from 'components/Icon/data'
2 |
3 | Page({
4 | data: {
5 | blockRight:blockRight,visible_default: false
6 | },
7 | onOption (e: any) {
8 | const _that = this
9 | const { mark: { type } } = e
10 |
11 | if (!type) return
12 |
13 | _that.setData({
14 | [`visible_${type}`]: true
15 | })
16 | }
17 | })
--------------------------------------------------------------------------------
/miniprogram/pages/NoticeBar/index.json:
--------------------------------------------------------------------------------
1 | {
2 | "navigationBarTitleText": "NoticeBar"
3 | }
--------------------------------------------------------------------------------
/miniprogram/pages/NoticeBar/index.less:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/MatrixAges/light-design/63031aa4a62c0ceda8802ad5c186778b637e45ff/miniprogram/pages/NoticeBar/index.less
--------------------------------------------------------------------------------
/miniprogram/pages/NoticeBar/index.ts:
--------------------------------------------------------------------------------
1 | Page({
2 | data: {
3 | list: [
4 | '叫大家圣诞节啊撒撒娇的叫大家圣诞节啊撒撒娇的叫大家圣诞节啊撒撒娇的',
5 | '叫大家都觉得卡开始的卡上课的卡上课叫大家圣诞节啊撒撒娇的',
6 | '叫大家圣诞节啊撒撒娇的叫大家圣诞节啊撒撒娇的',
7 | '叫大家都觉得卡开始的卡上课的卡上课叫大家圣诞节啊撒撒娇的',
8 | '叫大家圣诞节啊撒撒娇的叫大家圣诞节啊撒撒娇的',
9 | '叫大家都觉得卡开始的卡上课的卡上课叫大家圣诞节啊撒撒娇的'
10 | ]
11 | }
12 | })
13 |
--------------------------------------------------------------------------------
/miniprogram/pages/Period/index.json:
--------------------------------------------------------------------------------
1 | {
2 | "navigationBarTitleText": "Period"
3 | }
--------------------------------------------------------------------------------
/miniprogram/pages/Period/index.less:
--------------------------------------------------------------------------------
1 | .period_data {
2 | width: 80vw;
3 | padding: 48rpx;
4 | border-radius: 12rpx;
5 | font-size: 26rpx;
6 |
7 | .period_items {
8 | .period_item {
9 | border: 2rpx solid black;
10 | border-radius: 6rpx;
11 | overflow: hidden;
12 |
13 | &:first-child {
14 | margin-bottom: 18rpx;
15 | }
16 |
17 | .label {
18 | width: 48rpx;
19 | height: 100rpx;
20 | text-align: center;
21 | box-sizing: border-box;
22 | background-color: black;
23 | color: white;
24 | }
25 |
26 | .value_items {
27 | width: calc(100% - 48rpx);
28 | height: 100rpx;
29 | padding: 0 24rpx;
30 | border-radius: 6rpx;
31 |
32 | .value_item {
33 | &.text {
34 | font-size: 28rpx;
35 | font-weight: bold;
36 | }
37 |
38 | &.raw {
39 | font-size: 20rpx;
40 | }
41 | }
42 | }
43 | }
44 | }
45 | }
--------------------------------------------------------------------------------
/miniprogram/pages/Period/index.ts:
--------------------------------------------------------------------------------
1 | import { blockRight } from 'components/Icon/data'
2 |
3 | Page({
4 | data: {
5 | blockRight: blockRight,
6 | visible_default: false,
7 | visible_period_data: false,
8 | period_data: {}
9 | },
10 | onOption (e: any) {
11 | const _that = this
12 | const { mark: { type } } = e
13 |
14 | if (!type) return
15 |
16 | _that.setData({
17 | [`visible_${type}`]: true
18 | })
19 | },
20 | onSelectedPeriod ({ detail }: WechatMiniprogram.TouchEvent) {
21 | const _that = this
22 |
23 | _that.setData({
24 | visible_period_data: true,
25 | period_data: JSON.parse(JSON.stringify(detail))
26 | })
27 | }
28 | })
29 |
--------------------------------------------------------------------------------
/miniprogram/pages/Popover/index.json:
--------------------------------------------------------------------------------
1 | {
2 | "navigationBarTitleText": "Popover"
3 | }
--------------------------------------------------------------------------------
/miniprogram/pages/Popover/index.less:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/MatrixAges/light-design/63031aa4a62c0ceda8802ad5c186778b637e45ff/miniprogram/pages/Popover/index.less
--------------------------------------------------------------------------------
/miniprogram/pages/Popover/index.ts:
--------------------------------------------------------------------------------
1 | import { blockRight } from 'components/Icon/data'
2 |
3 | Page({
4 | data: {
5 | blockRight:blockRight,visible_default: false,
6 | list: [
7 | {
8 | name: '发起群聊',
9 | icon: '/image/icon_chat.svg'
10 | },
11 | {
12 | name: '添加朋友',
13 | icon: '/image/icon_add_person.svg'
14 | },
15 | {
16 | name: '扫一扫',
17 | icon: '/image/icon_scan.svg'
18 | },
19 | {
20 | name: '收付款',
21 | icon: '/image/icon_pay.svg'
22 | },
23 | {
24 | name: '帮助与反馈',
25 | icon: '/image/icon_feedback.svg'
26 | }
27 | ],
28 | list_black: [
29 | {
30 | name: '发起群聊',
31 | icon: '/image/icon_chat_black.svg'
32 | },
33 | {
34 | name: '添加朋友',
35 | icon: '/image/icon_add_person_black.svg'
36 | },
37 | {
38 | name: '扫一扫',
39 | icon: '/image/icon_scan_black.svg'
40 | },
41 | {
42 | name: '收付款',
43 | icon: '/image/icon_pay_black.svg'
44 | },
45 | {
46 | name: '帮助与反馈',
47 | icon: '/image/icon_feedback_black.svg'
48 | }
49 | ],
50 | },
51 | onOption (e: any) {
52 | const _that = this
53 | const { mark: { type } } = e
54 |
55 | if (!type) return
56 |
57 | _that.setData({
58 | [`visible_${type}`]: true
59 | })
60 | }
61 | })
62 |
--------------------------------------------------------------------------------
/miniprogram/pages/Ripple/index.json:
--------------------------------------------------------------------------------
1 | {
2 | "navigationBarTitleText": "Ripple"
3 | }
--------------------------------------------------------------------------------
/miniprogram/pages/Ripple/index.less:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/MatrixAges/light-design/63031aa4a62c0ceda8802ad5c186778b637e45ff/miniprogram/pages/Ripple/index.less
--------------------------------------------------------------------------------
/miniprogram/pages/Ripple/index.ts:
--------------------------------------------------------------------------------
1 | import { blockRight } from 'components/Icon/data'
2 |
3 | Page({
4 | data: {
5 | blockRight:blockRight,visible_default: false
6 | },
7 | onOption (e: any) {
8 | const _that = this
9 | const { mark: { type } } = e
10 |
11 | if (!type) return
12 |
13 | _that.setData({
14 | [`visible_${type}`]: true
15 | })
16 | },
17 | click () {
18 | wx.showToast({
19 | icon: 'none',
20 | title: 'clicked'
21 | })
22 | }
23 | })
24 |
--------------------------------------------------------------------------------
/miniprogram/pages/SnackBar/index.json:
--------------------------------------------------------------------------------
1 | {
2 | "navigationBarTitleText": "SnackBar"
3 | }
--------------------------------------------------------------------------------
/miniprogram/pages/SnackBar/index.less:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/MatrixAges/light-design/63031aa4a62c0ceda8802ad5c186778b637e45ff/miniprogram/pages/SnackBar/index.less
--------------------------------------------------------------------------------
/miniprogram/pages/SnackBar/index.ts:
--------------------------------------------------------------------------------
1 | import { blockRight } from 'components/Icon/data'
2 |
3 | Page({
4 | data: {
5 | blockRight:blockRight,visible_default: false
6 | },
7 | onOption ({ mark: { type } }: any) {
8 | const _that = this
9 |
10 | if (!type) return
11 |
12 | _that.setData({
13 | [`visible_${type}`]: true
14 | })
15 | },
16 | hide ({ mark: { type } }: any) {
17 | const _that = this
18 |
19 | if (!type) return
20 |
21 | _that.setData({
22 | [`visible_${type}`]: false
23 | })
24 | }
25 | })
26 |
--------------------------------------------------------------------------------
/miniprogram/pages/Sticky/index.json:
--------------------------------------------------------------------------------
1 | {
2 | "navigationBarTitleText": "Sticky"
3 | }
--------------------------------------------------------------------------------
/miniprogram/pages/Sticky/index.less:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/MatrixAges/light-design/63031aa4a62c0ceda8802ad5c186778b637e45ff/miniprogram/pages/Sticky/index.less
--------------------------------------------------------------------------------
/miniprogram/pages/Sticky/index.ts:
--------------------------------------------------------------------------------
1 | Page({})
2 |
--------------------------------------------------------------------------------
/miniprogram/pages/Sticky/index.wxml:
--------------------------------------------------------------------------------
1 |
2 |
3 |
4 |
5 |
6 | 默认效果
7 | default
8 |
9 |
10 |
11 |
12 | 默认效果
13 |
14 |
15 |
16 |
17 |
18 |
19 | 顶部距离
20 | offsetTop
21 |
22 |
23 |
24 |
25 | 顶部距离
26 |
27 |
28 |
29 |
30 |
31 |
32 |
33 | 指定容器
34 | container
35 |
36 |
37 |
42 |
43 |
47 |
54 | Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor
55 | incididunt
56 | ut labore et dolore magna aliqua.
57 |
58 |
59 |
60 |
61 |
62 |
63 |
64 |
--------------------------------------------------------------------------------
/miniprogram/pages/Tab/index.json:
--------------------------------------------------------------------------------
1 | {
2 | "navigationBarTitleText": "Tab"
3 | }
--------------------------------------------------------------------------------
/miniprogram/pages/Tab/index.less:
--------------------------------------------------------------------------------
1 | .content_item {
2 | box-sizing: border-box;
3 | height: 300rpx;
4 | background-color: white;
5 | color: #aaa;
6 | font-size: 26rpx;
7 | }
8 |
9 | .example_items {
10 | .example_item {
11 | .title_wrap {
12 | align-items: center;
13 | flex-direction: column;
14 |
15 | .title {
16 | margin-bottom: 12rpx;
17 | font-weight: normal;
18 | font-size: 24rpx;
19 | }
20 | }
21 | }
22 | }
--------------------------------------------------------------------------------
/miniprogram/pages/Tab/index.ts:
--------------------------------------------------------------------------------
1 | Page({
2 | data: {
3 | visible_default: false,
4 | titles: [ '新闻', '视频', '图片', '军事', '体育', 'NBA', '娱乐', '财经', '科技', '时尚', ],
5 | titles_1: [ '微博热搜榜', '今日头条', '吃瓜' ],
6 | },
7 | onOption(e: any) {
8 | const _that = this
9 | const { mark: { type } } = e
10 |
11 | if (!type) return
12 |
13 | _that.setData({
14 | [ `visible_${type}` ]: true
15 | })
16 |
17 | }
18 | })
19 |
--------------------------------------------------------------------------------
/miniprogram/pages/Text/index.json:
--------------------------------------------------------------------------------
1 | {
2 | "navigationBarTitleText": "Text"
3 | }
--------------------------------------------------------------------------------
/miniprogram/pages/Text/index.less:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/MatrixAges/light-design/63031aa4a62c0ceda8802ad5c186778b637e45ff/miniprogram/pages/Text/index.less
--------------------------------------------------------------------------------
/miniprogram/pages/Text/index.ts:
--------------------------------------------------------------------------------
1 | Page({})
--------------------------------------------------------------------------------
/miniprogram/pages/Toast/index.json:
--------------------------------------------------------------------------------
1 | {
2 | "navigationBarTitleText": "Toast"
3 | }
--------------------------------------------------------------------------------
/miniprogram/pages/Toast/index.less:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/MatrixAges/light-design/63031aa4a62c0ceda8802ad5c186778b637e45ff/miniprogram/pages/Toast/index.less
--------------------------------------------------------------------------------
/miniprogram/pages/Toast/index.ts:
--------------------------------------------------------------------------------
1 | import { blockRight } from 'components/Icon/data'
2 |
3 | Page({
4 | data: {
5 | blockRight:blockRight,visible_default: false,
6 | list: [
7 | {
8 | name: '朋友圈',
9 | icon: '/image/logo_pengyouquan.svg'
10 | },
11 | {
12 | name: '微信好友',
13 | icon: '/image/logo_wechat.svg'
14 | },
15 | {
16 | name: 'QQ空间',
17 | icon: '/image/logo_qzone.svg'
18 | },
19 | {
20 | name: 'QQ好友',
21 | icon: '/image/logo_qq.svg'
22 | },
23 | {
24 | name: '微博',
25 | icon: '/image/logo_weibo.svg'
26 | },
27 | {
28 | name: '钉钉',
29 | icon: '/image/logo_dingding.svg'
30 | },
31 | {
32 | name: '知乎',
33 | icon: '/image/logo_zhihu.svg'
34 | },
35 | {
36 | name: '易信',
37 | icon: '/image/logo_yixin.svg'
38 | },
39 | {
40 | name: 'instagram',
41 | icon: '/image/logo_instagram.svg'
42 | }
43 | ]
44 | },
45 | onOption (e: any) {
46 | const _that = this
47 | const { mark: { type } } = e
48 |
49 | if (!type) return
50 |
51 | _that.setData({
52 | [`visible_${type}`]: true
53 | })
54 |
55 | },
56 | onAction (e: any) {
57 | console.log(e)
58 | }
59 | })
60 |
--------------------------------------------------------------------------------
/miniprogram/pages/index/index.json:
--------------------------------------------------------------------------------
1 | {}
--------------------------------------------------------------------------------
/miniprogram/pages/index/index.less:
--------------------------------------------------------------------------------
1 | page {
2 | background-color: transparent;
3 | }
4 |
5 | .menu_items_wrap {
6 | padding: 36px;
7 |
8 | .menu_items {
9 | .menu_item {
10 | margin-bottom: 36px;
11 |
12 | .title_wrap {
13 | .title {
14 | flex: 1;
15 | padding: 12px 0;
16 | color: var(--color_text_sub);
17 | }
18 |
19 | .icon_close {
20 | display: none;
21 | }
22 | }
23 |
24 | .components {
25 | .component {
26 | width: calc(~'(100% - 24rpx) / 2');
27 | padding: 32rpx;
28 | margin-right: 24rpx;
29 | margin-bottom: 24rpx;
30 | border-top-right-radius: 36rpx;
31 | border-bottom-left-radius: 36rpx;
32 | box-shadow: var(--box_shadow_morphic);
33 | background-color: white;
34 |
35 | &:nth-of-type(2n) {
36 | margin-right: 0;
37 | }
38 |
39 | &.navigator-hover {
40 | opacity: 1;
41 | background-color: white;
42 | box-shadow: var(--box_shadow_morphic_active);
43 | }
44 |
45 | .description {
46 | font-size: 26rpx;
47 | color: var(--color_text_desc);
48 | }
49 | }
50 | }
51 | }
52 | }
53 | }
--------------------------------------------------------------------------------
/miniprogram/pages/index/index.ts:
--------------------------------------------------------------------------------
1 | import menu_items from '../../data/menu_items'
2 |
3 | Page({
4 | data: {
5 | menu_items
6 | }
7 | })
8 |
--------------------------------------------------------------------------------
/miniprogram/pages/index/index.wxml:
--------------------------------------------------------------------------------
1 |
--------------------------------------------------------------------------------
/miniprogram/sitemap.json:
--------------------------------------------------------------------------------
1 | {
2 | "desc": "关于本文件的更多信息,请参考文档 https://developers.weixin.qq.com/miniprogram/dev/framework/sitemap.html",
3 | "rules": [{
4 | "action": "allow",
5 | "page": "*"
6 | }]
7 | }
--------------------------------------------------------------------------------
/miniprogram/styles/init.less:
--------------------------------------------------------------------------------
1 | page {
2 | padding: 0;
3 | margin: 0;
4 | font-size: 30rpx;
5 | line-height: 1.5;
6 | color: black;
7 | background-color: white;
8 | -webkit-font-smoothing: antialiased;
9 | font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", "Roboto", "Oxygen", "Ubuntu", "Cantarell", "Fira Sans", "Droid Sans", "Helvetica Neue", sans-serif;
10 | text-rendering: geometricPrecision;
11 | }
12 |
13 | button {
14 | padding: 0;
15 | margin: 0;
16 | border: none;
17 | display: flex;
18 | justify-content: center;
19 | align-items: center;
20 | box-sizing: border-box;
21 | line-height: 1;
22 | font-weight: normal;
23 | transition: all ease 0.3s;
24 | }
25 |
26 | a {
27 | text-decoration: none;
28 | color: black;
29 | transition: all ease 0.3s;
30 |
31 | &:hover{
32 | color: black;
33 | transform: scale(1.02);
34 | }
35 |
36 | &:active{
37 | transform: scale(0.92);
38 | }
39 | }
40 |
41 | .navigator-hover{
42 | opacity: 1;
43 | }
--------------------------------------------------------------------------------
/miniprogram/styles/vars.less:
--------------------------------------------------------------------------------
1 | page {
2 | // variables lightd
3 | --height_button: 88rpx;
4 | --color_main: black;
5 | --color_success: #81C784;
6 | --color_warning: #FFB74D;
7 | --color_error: #E57373;
8 |
9 | // variables website
10 | --width_header: 1000px;
11 | --width_body: 1000px;
12 | --radius_button: 6px;
13 | --radius_normal: 12px;
14 | --radius_bottom: 20px;
15 | --color_border: rgba(245, 245, 245, 0.72);
16 | --color_border_deep: rgba(245, 245, 245, 0.9);
17 | --color_hover: rgba(245, 245, 245, 0.6);
18 | --color_text_main: rgba(0, 0, 0, 0.60);
19 | --color_text_sub: #aaaaaa;
20 | --color_text_desc: rgba(170, 170, 170, 0.72);
21 | --color_background: #fff;
22 | --color_sub_bg: #f7f8f9;
23 |
24 | // variables morphic
25 | --box_shadow_normal: 0 0 18px rgba(55, 84, 170, 0.15);
26 | --box_shadow_morphic: inset 0 0 15px rgba(55, 84, 170, 0),
27 | inset 0 0 20px rgba(255, 255, 255, 0),
28 | 10px 10px 18px rgba(55, 84, 170, 0.15),
29 | -10px -10px 22px white,
30 | inset 0px 0px 4px rgba(255, 255, 255, 0.2);
31 | --box_shadow_morphic_top: inset 0 0 15px rgba(55, 84, 170, 0),
32 | inset 0 0 20px rgba(255, 255, 255, 0),
33 | 10px -10px 18px rgba(55, 84, 170, 0.15),
34 | -10px -10px 22px white,
35 | inset 0px 0px 4px rgba(255, 255, 255, 0.2);
36 | --box_shadow_morphic_active: inset 7px 7px 15px rgba(55, 84, 170, 0.15), inset -7px -7px 20px white, 0px 0px 4px rgba(255, 255, 255, 0.2);
37 | }
--------------------------------------------------------------------------------
/miniprogram/utils/util.js:
--------------------------------------------------------------------------------
1 | "use strict";
2 | Object.defineProperty(exports, "__esModule", { value: true });
3 | exports.formatTime = void 0;
4 | exports.formatTime = function (date) {
5 | var year = date.getFullYear();
6 | var month = date.getMonth() + 1;
7 | var day = date.getDate();
8 | var hour = date.getHours();
9 | var minute = date.getMinutes();
10 | var second = date.getSeconds();
11 | return ([year, month, day].map(formatNumber).join('/') +
12 | ' ' +
13 | [hour, minute, second].map(formatNumber).join(':'));
14 | };
15 | var formatNumber = function (n) {
16 | var s = n.toString();
17 | return s[1] ? s : '0' + s;
18 | };
19 |
--------------------------------------------------------------------------------
/miniprogram/utils/util.ts:
--------------------------------------------------------------------------------
1 | export const formatTime = (date: Date) => {
2 | const year = date.getFullYear()
3 | const month = date.getMonth() + 1
4 | const day = date.getDate()
5 | const hour = date.getHours()
6 | const minute = date.getMinutes()
7 | const second = date.getSeconds()
8 |
9 | return (
10 | [year, month, day].map(formatNumber).join('/') +
11 | ' ' +
12 | [hour, minute, second].map(formatNumber).join(':')
13 | )
14 | }
15 |
16 | const formatNumber = (n: number) => {
17 | const s = n.toString()
18 | return s[1] ? s : '0' + s
19 | }
20 |
--------------------------------------------------------------------------------
/package.json:
--------------------------------------------------------------------------------
1 | {
2 | "name": "light-design",
3 | "version": "1.0.0",
4 | "description": "Components close to nature.",
5 | "homepage": "lightd.matrixages.com",
6 | "repository": {
7 | "type": "git",
8 | "url": "git@github.com:MatrixAges/light-design.git"
9 | },
10 | "scripts": {
11 | "build:es5": "webpack --mode production --config webpack/es5/webpack.config.js && cd webpack/es5 && node build",
12 | "dev": "cross-env NODE_ENV=development webpack --mode development --watch --config ./webpack/webpack.config.common.js",
13 | "build": "cross-env NODE_ENV=production webpack --mode production --config ./webpack/webpack.config.common.js",
14 | "ctrl + c": "退出后还会监听,需要手动 kill 进程"
15 | },
16 | "main": "dist/miniprogram/app.js",
17 | "keywords": [
18 | "微信小程序",
19 | "微信",
20 | "小程序",
21 | "组件",
22 | "组件库",
23 | "ui",
24 | "component",
25 | "design",
26 | "miniapp",
27 | "wxapp",
28 | "weapp",
29 | "miniprogram"
30 | ],
31 | "author": "Matrixage",
32 | "license": "MIT",
33 | "dependencies": {},
34 | "devDependencies": {
35 | "@babel/core": "^7.12.3",
36 | "@types/wechat-miniprogram": "^3.3.0",
37 | "babel-loader": "^8.1.0",
38 | "cache-loader": "^4.1.0",
39 | "clean-webpack-plugin": "^3.0.0",
40 | "copy-webpack-plugin": "^6.3.0",
41 | "cross-env": "^7.0.2",
42 | "cssnano": "^4.1.10",
43 | "dotenv-webpack": "^5.1.0",
44 | "file-loader": "^6.2.0",
45 | "filemanager-webpack-plugin": "^3.0.0-beta.0",
46 | "ignore-emit-webpack-plugin": "^2.0.5",
47 | "lerna": "^3.22.1",
48 | "less": "^3.12.2",
49 | "less-loader": "^7.0.2",
50 | "mini-program-webpack-loader": "^1.1.1",
51 | "miniprogram-api-typings": "3.1.3",
52 | "postcss": "^8.1.6",
53 | "postcss-loader": "^4.0.4",
54 | "purgecss-webpack-plugin": "^3.0.0",
55 | "ts-loader": "^8.0.10",
56 | "typescript": "4.0.3",
57 | "webpack": "^4.46.0",
58 | "webpack-bundle-analyzer": "^4.1.0",
59 | "webpack-cli": "^4.5.0",
60 | "webpack-merge": "^5.3.0"
61 | }
62 | }
--------------------------------------------------------------------------------
/tsconfig.json:
--------------------------------------------------------------------------------
1 | {
2 | "compilerOptions": {
3 | "strictNullChecks": true,
4 | "noImplicitAny": true,
5 | "module": "ES2020",
6 | "target": "ES5",
7 | "allowJs": true,
8 | "experimentalDecorators": true,
9 | "noImplicitThis": true,
10 | "noImplicitReturns": true,
11 | "alwaysStrict": true,
12 | "inlineSourceMap": false,
13 | "inlineSources": false,
14 | "noFallthroughCasesInSwitch": true,
15 | "noUnusedLocals": true,
16 | "noUnusedParameters": true,
17 | "strict": true,
18 | "removeComments": true,
19 | "pretty": false,
20 | "strictPropertyInitialization": true,
21 | "skipLibCheck": true,
22 | "skipDefaultLibCheck": true,
23 | "noStrictGenericChecks": true,
24 | "lib": [
25 | "es5",
26 | "es2016"
27 | ],
28 | "typeRoots": [
29 | "./typings"
30 | ],
31 | "baseUrl": "./",
32 | "paths": {
33 | "@/*": [
34 | "miniprogram/*"
35 | ],
36 | "components/*": [
37 | "miniprogram/components/*"
38 | ],
39 | "page_components/*": [
40 | "miniprogram/page_components/*"
41 | ]
42 | },
43 | },
44 | "include": [
45 | "**/*.ts"
46 | ],
47 | "exclude": [
48 | "node_modules"
49 | ]
50 | }
--------------------------------------------------------------------------------
/typings/index.d.ts:
--------------------------------------------------------------------------------
1 | ///
2 |
3 | interface IAppOption {
4 | globalData: {
5 | userInfo?: WechatMiniprogram.UserInfo
6 | }
7 | userInfoReadyCallback?: WechatMiniprogram.GetUserInfoSuccessCallback
8 | }
9 |
--------------------------------------------------------------------------------
/webpack/es5/build.js:
--------------------------------------------------------------------------------
1 | const child_process = require('child_process')
2 |
3 | child_process.exec('tsc --project ./compile.tsconfig.json')
4 |
--------------------------------------------------------------------------------
/webpack/es5/compile.tsconfig.json:
--------------------------------------------------------------------------------
1 | {
2 | "compilerOptions": {
3 | "strictNullChecks": true,
4 | "noImplicitAny": true,
5 | "module": "ES2020",
6 | "target": "ES5",
7 | "allowJs": true,
8 | "experimentalDecorators": true,
9 | "noImplicitThis": true,
10 | "noImplicitReturns": true,
11 | "alwaysStrict": true,
12 | "inlineSourceMap": false,
13 | "inlineSources": false,
14 | "noFallthroughCasesInSwitch": true,
15 | "noUnusedLocals": true,
16 | "noUnusedParameters": true,
17 | "strict": true,
18 | "removeComments": true,
19 | "pretty": true,
20 | "strictPropertyInitialization": true,
21 | "skipLibCheck": true,
22 | "skipDefaultLibCheck": true,
23 | "noStrictGenericChecks": true,
24 | "lib": [
25 | "es5",
26 | "es2016"
27 | ],
28 | "baseUrl": "./",
29 | "outDir": "../../miniprogram/components_es5/components"
30 | },
31 | "include": [
32 | "../../miniprogram/components"
33 | ]
34 | }
--------------------------------------------------------------------------------
/webpack/es5/loaders.js:
--------------------------------------------------------------------------------
1 | const { paths, fileLoader } = require('../utils')
2 |
3 | module.exports = [
4 | {
5 | test: /\.ts$/,
6 | exclude: paths.node_modules,
7 | use: [ 'cache-loader', 'ts-loader?transpileOnly' ]
8 | },
9 | {
10 | test: /.wxml/,
11 | use: [ fileLoader('[path][name].[ext]'), 'mini-program-webpack-loader' ]
12 | },
13 | {
14 | test: /\.wxss$/,
15 | use: [ fileLoader('[path][name].[ext]'), 'mini-program-webpack-loader' ]
16 | },
17 | {
18 | test: /\.less$/,
19 | use: [ fileLoader('[path][name].wxss'), 'less-loader' ]
20 | },
21 | {
22 | test: /.wxs$/,
23 | use: [ fileLoader('[path][name].[ext]'), 'babel-loader', 'mini-program-webpack-loader' ]
24 | },
25 | {
26 | test: /\.json$/,
27 | type: 'javascript/auto',
28 | use: [ fileLoader('[path][name].[ext]') ]
29 | }
30 | ]
31 |
--------------------------------------------------------------------------------
/webpack/es5/plugins.js:
--------------------------------------------------------------------------------
1 | const IgnoreEmitPlugin = require('ignore-emit-webpack-plugin')
2 | const { CleanWebpackPlugin } = require('clean-webpack-plugin')
3 | const MiniProgramPlugin = require('mini-program-webpack-loader').plugin
4 | const CopyWebpackPlugin = require('copy-webpack-plugin')
5 | const FileManagerPlugin = require('filemanager-webpack-plugin')
6 | const { resolve } = require('../utils')
7 |
8 | module.exports = [
9 | new IgnoreEmitPlugin('.DS_Store'),
10 | new CleanWebpackPlugin(),
11 | new MiniProgramPlugin({
12 | extfile: false
13 | }),
14 | new CopyWebpackPlugin({
15 | patterns: [
16 | {
17 | from: resolve('miniprogram/components/**/*/package.json')
18 | },
19 | {
20 | from: resolve('miniprogram/components/**/*/readme.md')
21 | }
22 | ]
23 | }),
24 | new FileManagerPlugin({
25 | runTasksInSeries: true,
26 | events: {
27 | onEnd: {
28 | delete: [
29 | resolve('miniprogram/components_es5/pages'),
30 | resolve('miniprogram/components_es5/page_components'),
31 | resolve('miniprogram/components_es5/app.js'),
32 | resolve('miniprogram/components_es5/app.json'),
33 | resolve('miniprogram/components_es5/app.wxss'),
34 | resolve('miniprogram/components_es5/webpack-require.js'),
35 | resolve('miniprogram/components_es5/**/*.js')
36 | ]
37 | }
38 | }
39 | })
40 | ]
41 |
--------------------------------------------------------------------------------
/webpack/es5/webpack.config.js:
--------------------------------------------------------------------------------
1 | const { paths } = require('../utils')
2 | const resolve = require('../resolve')
3 | const loaders = require('./loaders')
4 | const plugins = require('./plugins')
5 |
6 | module.exports = {
7 | context: paths.miniprogram,
8 | entry: paths.app_json,
9 | output: { path: paths.components_es5 },
10 | resolve: resolve,
11 | module: { rules: loaders },
12 | plugins: plugins,
13 | optimization: {
14 | minimize: false
15 | }
16 | }
17 |
--------------------------------------------------------------------------------
/webpack/loaders.js:
--------------------------------------------------------------------------------
1 | const { paths, fileLoader } = require('./utils')
2 |
3 | module.exports = [
4 | {
5 | test: /\.ts$/,
6 | exclude: paths.node_modules,
7 | use: [ 'cache-loader', 'ts-loader?transpileOnly' ]
8 | },
9 | {
10 | test: /.wxml/,
11 | use: [ fileLoader('[path][name].[ext]'), 'mini-program-webpack-loader' ]
12 | },
13 | {
14 | test: /\.wxss$/,
15 | use: [ fileLoader('[path][name].[ext]'), 'mini-program-webpack-loader' ]
16 | },
17 | {
18 | test: /\.less$/,
19 | use: [
20 | fileLoader('[path][name].wxss'),
21 | {
22 | loader: 'postcss-loader',
23 | options: { postcssOptions: { plugins: [ [ 'cssnano' ] ] } }
24 | },
25 | 'less-loader'
26 | ]
27 | },
28 | {
29 | test: /.wxs$/,
30 | use: [ fileLoader('[path][name].[ext]'), 'babel-loader', 'mini-program-webpack-loader' ]
31 | },
32 | {
33 | test: /\.json$/,
34 | type: 'javascript/auto',
35 | use: [ fileLoader('[path][name].[ext]') ]
36 | }
37 | ]
38 |
--------------------------------------------------------------------------------
/webpack/plugins.js:
--------------------------------------------------------------------------------
1 | const path = require('path')
2 | const MiniProgramPlugin = require('mini-program-webpack-loader').plugin
3 | const IgnoreEmitPlugin = require('ignore-emit-webpack-plugin')
4 | const CopyWebpackPlugin = require('copy-webpack-plugin')
5 | const { resolve } = require('./utils')
6 |
7 | module.exports = [
8 | new IgnoreEmitPlugin('.DS_Store'),
9 | new MiniProgramPlugin({
10 | extfile: false
11 | }),
12 | new CopyWebpackPlugin({
13 | patterns: [
14 | {
15 | from: path.posix.join(
16 | path.resolve(__dirname, '../miniprogram').replace(/\\/g, '/'),
17 | '/**/*.(svg|png|jpg|jpeg|gif)'
18 | ),
19 | to: '[path][name].[ext]'
20 | },
21 | {
22 | from: resolve('miniprogram/sitemap.json'),
23 | to: resolve('dist/sitemap.json')
24 | }
25 | ]
26 | })
27 | ]
28 |
--------------------------------------------------------------------------------
/webpack/resolve.js:
--------------------------------------------------------------------------------
1 | const { paths } = require('./utils')
2 |
3 | module.exports = {
4 | extensions: [ '.ts', '.js', '.json' ],
5 | alias: {
6 | '@': paths.miniprogram,
7 | components: paths.components,
8 | page_components: paths.page_components
9 | }
10 | }
11 |
--------------------------------------------------------------------------------
/webpack/utils.js:
--------------------------------------------------------------------------------
1 | const path = require('path')
2 |
3 | const resolve = (file) => path.resolve(__dirname, '../', file)
4 | const fileLoader = (name) => ({
5 | loader: 'file-loader',
6 | options: {
7 | publicPath: '',
8 | context: paths.miniprogram || paths.root,
9 | name
10 | }
11 | })
12 |
13 | const is_dev = process.env.NODE_ENV === 'development'
14 | const paths = {
15 | dist: resolve('dist'),
16 | node_modules: resolve('node_modules'),
17 | miniprogram: resolve('miniprogram'),
18 | app_json: resolve('miniprogram/app.json'),
19 | dist_app_json: resolve('dist/app.json'),
20 | components: resolve('miniprogram/components'),
21 | page_components: resolve('miniprogram/page_components'),
22 | components_es5: resolve('miniprogram/components_es5')
23 | }
24 |
25 | module.exports = {
26 | resolve,
27 | fileLoader,
28 | is_dev,
29 | paths
30 | }
--------------------------------------------------------------------------------
/webpack/webpack.config.common.js:
--------------------------------------------------------------------------------
1 | const { merge } = require('webpack-merge')
2 | const resolve = require('./resolve')
3 | const loaders = require('./loaders')
4 | const plugins = require('./plugins')
5 | const devConfig = require('./webpack.config.dev')
6 | const prodConfig = require('./webpack.config.prod')
7 | const { is_dev, paths } = require('./utils')
8 |
9 | //@ts-ignore
10 | global.context = paths.miniprogram
11 |
12 | module.exports = merge(is_dev ? devConfig : prodConfig, {
13 | context: paths.miniprogram,
14 | entry: paths.app_json,
15 | output: { path: paths.dist },
16 | resolve: resolve,
17 | module: { rules: loaders },
18 | plugins: plugins
19 | })
20 |
--------------------------------------------------------------------------------
/webpack/webpack.config.dev.js:
--------------------------------------------------------------------------------
1 | const webpack = require('webpack')
2 |
3 | module.exports = {
4 | mode: 'development',
5 | target: 'node',
6 | devtool: false,
7 | watchOptions: {
8 | ignored: /node_modules|dist/,
9 | poll: 1000
10 | },
11 | optimization: {
12 | splitChunks: {
13 | cacheGroups: {
14 | commons: {
15 | name: 'commons',
16 | chunks: 'initial',
17 | minChunks: 2
18 | }
19 | }
20 | }
21 | },
22 | plugins: [
23 | new webpack.DefinePlugin({
24 | PRODUCTION: JSON.stringify(process.env.NODE_ENV === 'development')
25 | })
26 | ]
27 | }
28 |
--------------------------------------------------------------------------------
/webpack/webpack.config.prod.js:
--------------------------------------------------------------------------------
1 | const { CleanWebpackPlugin } = require('clean-webpack-plugin')
2 | const { BundleAnalyzerPlugin } = require('webpack-bundle-analyzer')
3 | const webpack = require('webpack')
4 |
5 | module.exports = {
6 | mode: 'production',
7 | target: 'node',
8 | devtool: false,
9 | optimization: {
10 | minimize: true,
11 | splitChunks: {
12 | cacheGroups: {
13 | commons: {
14 | name: 'commons',
15 | chunks: 'initial',
16 | minChunks: 2
17 | }
18 | }
19 | }
20 | },
21 | plugins: [
22 | new CleanWebpackPlugin(),
23 | new BundleAnalyzerPlugin(),
24 | new webpack.DefinePlugin({
25 | PRODUCTION: JSON.stringify(process.env.NODE_ENV === 'production')
26 | })
27 | ]
28 | }
29 |
--------------------------------------------------------------------------------