Initial commit

This commit is contained in:
yuantao
2025-09-29 14:05:25 +08:00
commit 6f0bb2f949
579 changed files with 99061 additions and 0 deletions

View File

@@ -0,0 +1,311 @@
.u-primary-light {
color: $u-primary-light;
}
.u-warning-light {
color: $u-warning-light;
}
.u-success-light {
color: $u-success-light;
}
.u-error-light {
color: $u-error-light;
}
.u-info-light {
color: $u-info-light;
}
.u-primary-light-bg {
background-color: $u-primary-light;
}
.u-warning-light-bg {
background-color: $u-warning-light;
}
.u-success-light-bg {
background-color: $u-success-light;
}
.u-error-light-bg {
background-color: $u-error-light;
}
.u-info-light-bg {
background-color: $u-info-light;
}
.u-primary-dark {
color: $u-primary-dark;
}
.u-warning-dark {
color: $u-warning-dark;
}
.u-success-dark {
color: $u-success-dark;
}
.u-error-dark {
color: $u-error-dark;
}
.u-info-dark {
color: $u-info-dark;
}
.u-primary-dark-bg {
background-color: $u-primary-dark;
}
.u-warning-dark-bg {
background-color: $u-warning-dark;
}
.u-success-dark-bg {
background-color: $u-success-dark;
}
.u-error-dark-bg {
background-color: $u-error-dark;
}
.u-info-dark-bg {
background-color: $u-info-dark;
}
.u-primary-disabled {
color: $u-primary-disabled;
}
.u-warning-disabled {
color: $u-warning-disabled;
}
.u-success-disabled {
color: $u-success-disabled;
}
.u-error-disabled {
color: $u-error-disabled;
}
.u-info-disabled {
color: $u-info-disabled;
}
.u-primary {
color: $u-primary;
}
.u-warning {
color: $u-warning;
}
.u-success {
color: $u-success;
}
.u-error {
color: $u-error;
}
.u-info {
color: $u-info;
}
.u-primary-bg {
background-color: $u-primary;
}
.u-warning-bg {
background-color: $u-warning;
}
.u-success-bg {
background-color: $u-success;
}
.u-error-bg {
background-color: $u-error;
}
.u-info-bg {
background-color: $u-info;
}
.u-main-color {
color: $u-main-color;
}
.u-content-color {
color: $u-content-color;
}
.u-tips-color {
color: $u-tips-color;
}
.u-light-color {
color: $u-light-color;
}
.up-primary-light {
color: $u-primary-light;
}
.up-warning-light {
color: $u-warning-light;
}
.up-success-light {
color: $u-success-light;
}
.up-error-light {
color: $u-error-light;
}
.up-info-light {
color: $u-info-light;
}
.up-primary-light-bg {
background-color: $u-primary-light;
}
.up-warning-light-bg {
background-color: $u-warning-light;
}
.up-success-light-bg {
background-color: $u-success-light;
}
.up-error-light-bg {
background-color: $u-error-light;
}
.up-info-light-bg {
background-color: $u-info-light;
}
.up-primary-dark {
color: $u-primary-dark;
}
.up-warning-dark {
color: $u-warning-dark;
}
.up-success-dark {
color: $u-success-dark;
}
.up-error-dark {
color: $u-error-dark;
}
.up-info-dark {
color: $u-info-dark;
}
.up-primary-dark-bg {
background-color: $u-primary-dark;
}
.up-warning-dark-bg {
background-color: $u-warning-dark;
}
.up-success-dark-bg {
background-color: $u-success-dark;
}
.up-error-dark-bg {
background-color: $u-error-dark;
}
.up-info-dark-bg {
background-color: $u-info-dark;
}
.up-primary-disabled {
color: $u-primary-disabled;
}
.up-warning-disabled {
color: $u-warning-disabled;
}
.up-success-disabled {
color: $u-success-disabled;
}
.up-error-disabled {
color: $u-error-disabled;
}
.up-info-disabled {
color: $u-info-disabled;
}
.up-primary {
color: $u-primary;
}
.up-warning {
color: $u-warning;
}
.up-success {
color: $u-success;
}
.up-error {
color: $u-error;
}
.up-info {
color: $u-info;
}
.up-primary-bg {
background-color: $u-primary;
}
.up-warning-bg {
background-color: $u-warning;
}
.up-success-bg {
background-color: $u-success;
}
.up-error-bg {
background-color: $u-error;
}
.up-info-bg {
background-color: $u-info;
}
.up-main-color {
color: $u-main-color;
}
.up-content-color {
color: $u-content-color;
}
.up-tips-color {
color: $u-tips-color;
}
.up-light-color {
color: $u-light-color;
}

View File

@@ -0,0 +1,112 @@
// 超出行数自动显示行尾省略号最多5行
// 来自uview-plus的温馨提示当您在控制台看到此报错说明需要在App.vue的style标签加上【lang="scss"】
@for $i from 1 through 10 {
.u-line-#{$i},
.up-line-#{$i} {
/* #ifdef APP-NVUE */
// nvue下可以直接使用lines属性这是weex特有样式
lines: $i;
text-overflow: ellipsis;
overflow: hidden;
flex: 1;
/* #endif */
/* #ifndef APP-NVUE */
// vue下单行和多行显示省略号需要单独处理
@if $i == '1' {
overflow: hidden;
white-space: nowrap;
text-overflow: ellipsis;
} @else {
display: -webkit-box!important;
overflow: hidden;
text-overflow: ellipsis;
word-break: break-all;
-webkit-line-clamp: $i;
-webkit-box-orient: vertical!important;
}
/* #endif */
}
}
// 此处加上!important并非随意乱用而是因为目前*.nvue页面编译到H5时
// App.vue的样式会被uni-app的view元素的自带border属性覆盖导致无效
// 综上这是uni-app的缺陷导致我们为了多端兼容而必须要加上!important
// 移动端兼容性较好直接使用0.5px去实现细边框,不使用伪元素形式实现
.u-border,
.up-border {
border-width: 0.5px!important;
border-color: $u-border-color!important;
border-style: solid;
}
.u-border-top,
.up-border-top {
border-top-width: 0.5px!important;
border-color: $u-border-color!important;
border-top-style: solid;
}
.u-border-left,
.up-border-left {
border-left-width: 0.5px!important;
border-color: $u-border-color!important;
border-left-style: solid;
}
.u-border-right,
.up-border-right {
border-right-width: 0.5px!important;
border-color: $u-border-color!important;
border-right-style: solid;
}
.u-border-bottom,
.up-border-bottom {
border-bottom-width: 0.5px!important;
border-color: $u-border-color!important;
border-bottom-style: solid;
}
.u-border-top-bottom,
.up-border-top-bottom {
border-top-width: 0.5px!important;
border-bottom-width: 0.5px!important;
border-color: $u-border-color!important;
border-top-style: solid;
border-bottom-style: solid;
}
// 去除button的所有默认样式让其表现跟普通的view、text元素一样
.u-reset-button,
.up-reset-button {
padding: 0;
background-color: transparent;
/* #ifndef APP-PLUS */
font-size: inherit;
line-height: inherit;
color: inherit;
/* #endif */
/* #ifdef APP-NVUE */
border-width: 0;
/* #endif */
}
/* #ifndef APP-NVUE */
.u-reset-button::after,
.up-reset-button::after {
border: none;
}
/* #endif */
.u-hover-class,
.up-hover-class {
opacity: 0.7;
}
.cursor-pointer {
/* #ifdef H5 */
cursor: pointer;
/* #endif */
}

View File

@@ -0,0 +1,34 @@
@import "./mixin.scss";
/* #ifndef APP-NVUE */
// 由于uview-plus是基于nvue环境进行开发的此环境中普通元素默认为flex-direction: column;
// 所以在非nvue中需要对元素进行重置为flex-direction: column; 否则可能会表现异常
// 2024-04-09由于微信小程序会提示 Some selectors are not allowed in component wxss所以注释以下几行
// view,
// scroll-view,
// swiper-item,
.u-empty,
.u-empty__wrap,
.u-tabs,
.u-tabs__wrapper,
.u-tabs__wrapper__scroll-view-wrapper,
.u-tabs__wrapper__scroll-view,
.u-tabs__wrapper__nav,
.u-tabs__wrapper__nav__line,
.up-empty,
.up-empty__wrap,
.up-tabs,
.up-tabs__wrapper,
.up-tabs__wrapper__scroll-view-wrapper,
.up-tabs__wrapper__scroll-view,
.up-tabs__wrapper__nav,
.up-tabs__wrapper__nav__line {
display: flex;
flex-direction: column;
flex-shrink: 0;
flex-grow: 0;
flex-basis: auto;
align-items: stretch;
align-content: flex-start;
}
/* #endif */

View File

@@ -0,0 +1,364 @@
// .u-flex {
// @include vue-flex(row);
// }
// .u-flex-x {
// @include vue-flex(row);
// }
// .u-flex-y {
// @include vue-flex(column);
// }
// .u-flex-xy-center {
// @include vue-flex(row);
// justify-content: center;
// align-items: center;
// }
// .u-flex-x-center {
// @include vue-flex(row);
// justify-content: center;
// }
// .u-flex-y-center {
// @include vue-flex(column);
// justify-content: center;
// }
// flex布局
.u-flex,
.u-flex-row,
.u-flex-x,
.up-flex,
.up-flex-row,
.up-flex-x {
@include flex;
}
.u-flex-y,
.u-flex-column,
.up-flex-y,
.up-flex-column {
@include flex(column);
}
.u-flex-x-center,
.up-flex-x-center {
@include flex;
justify-content: center;
}
.u-flex-xy-center,
.up-flex-xy-center {
@include flex;
justify-content: center;
align-items: center;
}
.u-flex-y-center,
.up-flex-y-center {
@include flex;
align-items: center;
}
.u-flex-x-left,
.up-flex-x-left {
@include flex;
}
.u-flex-x-reverse,
.u-flex-row-reverse,
.up-flex-x-reverse,
.up-flex-row-reverse {
flex-direction: row-reverse;
}
.u-flex-y-reverse,
.u-flex-column-reverse,
.up-flex-y-reverse,
.up-flex-column-reverse {
flex-direction: column-reverse;
}
/* #ifndef APP-NVUE */
// 此处为vue版本的简写因为nvue不支持同时作用于两个类名的样式写法
// nvue下只能写成class="u-flex-x u-flex-x-reverse的形式"
.u-flex.u-flex-reverse,
.u-flex-row.u-flex-reverse,
.u-flex-x.u-flex-reverse,
.up-flex.up-flex-reverse,
.up-flex-row.up-flex-reverse,
.up-flex-x.up-flex-reverse {
flex-direction: row-reverse;
}
.u-flex-column.u-flex-reverse,
.u-flex-y.u-flex-reverse,
.up-flex-column.up-flex-reverse,
.up-flex-y.up-flex-reverse {
flex-direction: column-reverse;
}
// 自动伸缩
.u-flex-fill,
.up-flex-fill {
flex: 1 1 auto;
}
// 边界自动伸缩
.u-margin-top-auto,
.u-m-t-auto,
.up-margin-top-auto,
.up-m-t-auto {
margin-top: auto !important;
}
.u-margin-right-auto,
.u-m-r-auto,
.up-margin-right-auto,
.up-m-r-auto {
margin-right: auto !important;
}
.u-margin-bottom-auto,
.u-m-b-auto,
.up-margin-bottom-auto,
.up-m-b-auto {
margin-bottom: auto !important;
}
.u-margin-left-auto,
.u-m-l-auto,
.up-margin-left-auto,
.up-m-l-auto {
margin-left: auto !important;
}
.u-margin-center-auto,
.u-m-c-auto,
.up-margin-center-auto,
.up-m-c-auto {
margin-left: auto !important;
margin-right: auto !important;
}
.u-margin-middle-auto,
.u-m-m-auto,
.up-margin-middle-auto,
.up-m-m-auto {
margin-top: auto !important;
margin-bottom: auto !important;
}
/* #endif */
// 换行
.u-flex-wrap,
.up-flex-wrap {
flex-wrap: wrap;
}
// 反向换行
.u-flex-wrap-reverse,
.up-flex-wrap-reverse {
flex-wrap: wrap-reverse;
}
// 主轴起点对齐
.u-flex-start,
.up-flex-start {
justify-content: flex-start;
}
// 主轴中间对齐
.u-flex-center,
.up-flex-center {
justify-content: center;
}
// 主轴终点对齐
.u-flex-end,
.up-flex-end {
justify-content: flex-end;
}
// 主轴等比间距
.u-flex-between,
.up-flex-between {
justify-content: space-between;
}
// 主轴均分间距
.u-flex-around,
.up-flex-around {
justify-content: space-around;
}
// 交叉轴起点对齐
.u-flex-items-start,
.up-flex-items-start {
align-items: flex-start;
}
// 交叉轴中间对齐
.u-flex-items-center,
.up-flex-items-center {
align-items: center;
}
// 交叉轴终点对齐
.u-flex-items-end,
.up-flex-items-end {
align-items: flex-end;
}
// 交叉轴第一行文字基线对齐
.u-flex-items-baseline,
.up-flex-items-baseline {
/* #ifndef APP-NVUE */
align-items: baseline;
/* #endif */
}
// 交叉轴方向拉伸对齐
.u-flex-items-stretch,
.up-flex-items-stretch {
align-items: stretch;
}
// 以下属于项目(子元素)的类
// 子元素交叉轴起点对齐
/* #ifndef APP-NVUE */
.u-flex-self-start,
.up-flex-self-start {
align-self: flex-start;
}
// 子元素交叉轴居中对齐
.u-flex-self-center,
.up-flex-self-center {
align-self: center;
}
// 子元素交叉轴终点对齐
.u-flex-self-end,
.up-flex-self-end {
align-self: flex-end;
}
// 子元素交叉轴第一行文字基线对齐
.u-flex-self-baseline,
.up-flex-self-baseline {
align-self: baseline;
}
// 子元素交叉轴方向拉伸对齐
.u-flex-self-stretch,
.up-flex-self-stretch {
align-self: stretch;
}
/* #endif */
// 多轴交叉时的对齐方式
// 起点对齐
/* #ifndef APP-NVUE */
.u-flex-content-start,
.up-flex-content-start {
align-content: flex-start;
}
// 居中对齐
.u-flex-content-center,
.up-flex-content-center {
align-content: center;
}
// 终点对齐
.u-flex-content-end,
.up-flex-content-end {
align-content: flex-end;
}
// 两端对齐
.u-flex-content-between,
.up-flex-content-between {
align-content: space-between;
}
// 均分间距
.u-flex-content-around,
.up-flex-content-around {
align-content: space-around;
}
// 全部居中对齐
.u-flex-middle,
.up-flex-middle {
justify-content: center;
align-items: center;
align-self: center;
align-content: center;
}
// 是否可以放大
.u-flex-grow,
.up-flex-grow {
flex-grow: 1;
}
// 是否可以缩小
.u-flex-shrink,
.up-flex-shrink {
flex-shrink: 1;
}
/* #endif */
// 定义内外边距历遍1-80
@for $i from 0 through 80 {
// 只要双数和能被5除尽的数
@if $i % 2 == 0 or $i % 5 == 0 {
// 得出up-margin-30或者u-m-30
.u-margin-#{$i}, .u-m-#{$i},
.up-margin-#{$i}, .up-m-#{$i} {
margin: $i + rpx!important;
}
// 得出up-padding-30或者u-p-30
.u-padding-#{$i}, .u-p-#{$i},
.up-padding-#{$i}, .up-p-#{$i} {
padding: $i + rpx!important;
}
@each $short, $long in l left, t top, r right, b bottom {
// 缩写版,结果如: up-m-l-30
// 定义外边距
.u-m-#{$short}-#{$i},
.up-m-#{$short}-#{$i} {
margin-#{$long}: $i + rpx!important;
}
// 定义内边距
.u-p-#{$short}-#{$i},
.up-p-#{$short}-#{$i} {
padding-#{$long}: $i + rpx!important;
}
// 完整版结果如up-margin-left-30
// 定义外边距
.u-margin-#{$long}-#{$i},
.up-margin-#{$long}-#{$i} {
margin-#{$long}: $i + rpx!important;
}
// 定义内边距
.u-padding-#{$long}-#{$i},
.up-padding-#{$long}-#{$i} {
padding-#{$long}: $i + rpx!important;
}
}
}
}

View File

View File

@@ -0,0 +1,8 @@
// 通过scss的mixin功能把原来需要写4行的css变成一行
// 目的是保持代码干净整洁不至于在nvue下到处都要写display:flex的条件编译
@mixin flex($direction: row) {
/* #ifndef APP-NVUE */
display: flex;
/* #endif */
flex-direction: $direction;
}

View File

View File

View File

@@ -0,0 +1,28 @@
// 历遍生成4个方向的底部安全区
@each $d in top, right, bottom, left {
.u-safe-area-inset-#{$d},
.up-safe-area-inset-#{$d} {
padding-#{$d}: 0;
padding-#{$d}: constant(safe-area-inset-#{$d});
padding-#{$d}: env(safe-area-inset-#{$d});
}
}
//提升H5端uni.toast()的层级避免被uview-plus的modal等遮盖
/* #ifdef H5 */
uni-toast {
z-index: 10090;
}
uni-toast .uni-toast {
z-index: 10090;
}
/* #endif */
// 隐藏scroll-view的滚动条
::-webkit-scrollbar {
display: none;
width: 0 !important;
height: 0 !important;
-webkit-appearance: none;
background: transparent;
}