185 lines
		
	
	
		
			3.3 KiB
		
	
	
	
		
			SCSS
		
	
	
	
	
	
			
		
		
	
	
			185 lines
		
	
	
		
			3.3 KiB
		
	
	
	
		
			SCSS
		
	
	
	
	
	
| $clipper-edge-border-width: 6rpx !default;
 | |
| $clipper-confirm-color: #07c160 !default;
 | |
| 
 | |
| .flex-auto {
 | |
| 	flex:auto
 | |
| }
 | |
| 	
 | |
| .bg-transparent {
 | |
| 	background-color: rgba(0, 0, 0, 0.9);
 | |
| 	transition-duration: 0.35s;
 | |
| }
 | |
| 
 | |
| .lime-clipper {
 | |
| 	width: 100vw;
 | |
| 	height: calc( 100vh - var(--window-top));
 | |
| 	background-color: rgba(0, 0, 0, 0.9);
 | |
| 	position: fixed;
 | |
| 	top: var(--window-top);
 | |
| 	left: 300vw;
 | |
| 	z-index: 1;
 | |
| 	&.open {
 | |
| 		left: 0;
 | |
| 	}	
 | |
| 	&-mask {
 | |
| 		position: relative;
 | |
| 		z-index: 2;
 | |
| 		pointer-events: none;
 | |
| 	}
 | |
| 	&__content {
 | |
| 		pointer-events: none;
 | |
| 		position: absolute;
 | |
| 		border: 1rpx solid rgba(255,255,255,.3);
 | |
| 		box-sizing: border-box;
 | |
| 		box-shadow: rgba(0, 0, 0, 0.5) 0 0 0 80vh;
 | |
| 		background: transparent;	
 | |
| 		// transition-duration 0.35s
 | |
| 		// transition-property left,top
 | |
| 		&::before,&::after {
 | |
| 			content: '';
 | |
| 			position: absolute;
 | |
| 			border: 1rpx dashed rgba(255,255,255,.3);
 | |
| 		}
 | |
| 			
 | |
| 		&::before {
 | |
| 			width: 100%;
 | |
| 			top: 33.33%;
 | |
| 			height: 33.33%;
 | |
| 			border-left: none;
 | |
| 			border-right: none;
 | |
| 		}
 | |
| 			
 | |
| 		&::after {
 | |
| 			width: 33.33%;
 | |
| 			left: 33.33%;
 | |
| 			height: 100%;
 | |
| 			border-top:none;
 | |
| 			border-bottom: none;
 | |
| 		}
 | |
| 			
 | |
| 	}
 | |
| 		
 | |
| 	&__edge {
 | |
| 		position: absolute;
 | |
| 		// left 6rpx
 | |
| 		width: 34rpx;
 | |
| 		height: 34rpx;
 | |
| 		border: $clipper-edge-border-width solid #ffffff;
 | |
| 		pointer-events: auto;
 | |
| 		&::before {
 | |
| 			content: '';
 | |
| 			position: absolute;
 | |
| 			width: 40rpx;
 | |
| 			height: 40rpx;
 | |
| 			background-color: transparent;
 | |
| 		}
 | |
| 			
 | |
| 		&:nth-child(1) {
 | |
| 			left: - $clipper-edge-border-width;
 | |
| 			top: - $clipper-edge-border-width;
 | |
| 			border-bottom-width: 0 !important;
 | |
| 			border-right-width: 0 !important;
 | |
| 			&:before {
 | |
| 				top: -50%;
 | |
| 				left: -50%;
 | |
| 			}
 | |
| 		}
 | |
| 			
 | |
| 		&:nth-child(2) {
 | |
| 			right: - $clipper-edge-border-width;
 | |
| 			top: - $clipper-edge-border-width;
 | |
| 			border-bottom-width: 0 !important;
 | |
| 			border-left-width: 0 !important;
 | |
| 			&:before {
 | |
| 				top: -50%;
 | |
| 				left: 50%;
 | |
| 			}
 | |
| 				
 | |
| 		}
 | |
| 			
 | |
| 		&:nth-child(3) {
 | |
| 			left: - $clipper-edge-border-width;
 | |
| 			bottom: - $clipper-edge-border-width;
 | |
| 			border-top-width: 0 !important;
 | |
| 			border-right-width: 0 !important;
 | |
| 			&:before {
 | |
| 				bottom: -50%;
 | |
| 				left: -50%;
 | |
| 			}
 | |
| 		}
 | |
| 			
 | |
| 		&:nth-child(4) {
 | |
| 			right: - $clipper-edge-border-width;
 | |
| 			bottom: - $clipper-edge-border-width;
 | |
| 			border-top-width: 0 !important;
 | |
| 			border-left-width: 0 !important;
 | |
| 			&:before {
 | |
| 				bottom: -50%;
 | |
| 				left: 50%;
 | |
| 			}
 | |
| 		}
 | |
| 			
 | |
| 	}
 | |
| 		
 | |
| 	&-image {
 | |
| 		width: 100%;
 | |
| 		max-width: inherit;
 | |
| 		border-style: none;
 | |
| 		position: absolute;
 | |
| 		top: 0;
 | |
| 		left: 0;
 | |
| 		z-index: 1;
 | |
| 		-webkit-backface-visibility: hidden;
 | |
| 		backface-visibility: hidden;
 | |
| 		transform-origin: center;
 | |
| 	}
 | |
| 		
 | |
| 	&-canvas {
 | |
| 		position: fixed;
 | |
| 		z-index: 10;
 | |
| 		left: -200vw;
 | |
| 		top: -200vw;
 | |
| 		pointer-events: none;
 | |
| 	}
 | |
| 		
 | |
| 	&-tools {
 | |
| 		position: absolute;
 | |
| 		left: 0;
 | |
| 		bottom: 10px;
 | |
| 		width: 100%;
 | |
| 		z-index: 99;
 | |
| 		color: #fff;
 | |
| 		&__btns {
 | |
| 			font-weight: bold;
 | |
| 			display: flex;
 | |
| 			align-items: center;
 | |
| 			justify-content: space-between;
 | |
| 			width: 100%;
 | |
| 			padding: 20rpx 40rpx;
 | |
| 			box-sizing: border-box;
 | |
| 			.cancel {
 | |
| 				width: 112rpx;
 | |
| 				height: 60rpx;
 | |
| 				text-align: center;
 | |
| 				line-height: 60rpx;
 | |
| 			}
 | |
| 				
 | |
| 			.confirm {
 | |
| 				width: 112rpx;
 | |
| 				height: 60rpx;
 | |
| 				line-height: 60rpx;
 | |
| 				background: var(--lime-clipper-confirm-color, $clipper-confirm-color);
 | |
| 				border-radius: 6rpx;
 | |
| 				text-align: center;
 | |
| 			}
 | |
| 				
 | |
| 			image {
 | |
| 				display: block;
 | |
| 				width: 60rpx;
 | |
| 				height: 60rpx;
 | |
| 			}
 | |
| 		}	
 | |
| 	}		
 | |
| }
 | |
| 	
 |