89 lines
		
	
	
		
			2.2 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
		
		
			
		
	
	
			89 lines
		
	
	
		
			2.2 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
| 
								 | 
							
								const config = require('../config')
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								const build = {
							 | 
						||
| 
								 | 
							
								  import: 'prism.css',
							 | 
						||
| 
								 | 
							
								  handler (file) {
							 | 
						||
| 
								 | 
							
								    if (file.path.includes('prism.css')) {
							 | 
						||
| 
								 | 
							
								      // 将标签名选择器和属性选择器转为 class 选择器(组件内仅支持 class 选择器)
							 | 
						||
| 
								 | 
							
								      file.contents = Buffer.from(file.contents.toString().replace(/pre([[)])/g, '.hl-pre$1').replace(/code/g, '.hl-code').replace(/\[class\*="?language-"?\]/g, '').replace(/:not[^,}]+[,}]*/g, '').replace(/\.token\./g, '.hl-'))
							 | 
						||
| 
								 | 
							
								    }
							 | 
						||
| 
								 | 
							
								  }
							 | 
						||
| 
								 | 
							
								}
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								if (config.showLanguageName || config.showLineNumber) {
							 | 
						||
| 
								 | 
							
								  // pre 内部的 code 进行滚动,避免行号和语言名称跟随滚动
							 | 
						||
| 
								 | 
							
								  build.style = `.hl-pre {
							 | 
						||
| 
								 | 
							
								  position: relative;
							 | 
						||
| 
								 | 
							
								}
							 | 
						||
| 
								 | 
							
								.hl-code {
							 | 
						||
| 
								 | 
							
								  overflow: auto;
							 | 
						||
| 
								 | 
							
								  display: block;
							 | 
						||
| 
								 | 
							
								}`
							 | 
						||
| 
								 | 
							
								}
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								if (config.copyByLongPress) {
							 | 
						||
| 
								 | 
							
								  build.template = '<rich-text v-if="n.attrs&&n.attrs[\'data-content\']" :nodes="[n]" :data-content="n.attrs[\'data-content\']" :data-lang="n.attrs[\'data-lang\']" @longpress="copyCode" />'
							 | 
						||
| 
								 | 
							
								  build.methods = {
							 | 
						||
| 
								 | 
							
								    copyCode (e) {
							 | 
						||
| 
								 | 
							
								      uni.showActionSheet({
							 | 
						||
| 
								 | 
							
								        itemList: ['复制代码'],
							 | 
						||
| 
								 | 
							
								        success: () =>
							 | 
						||
| 
								 | 
							
								          uni.setClipboardData({
							 | 
						||
| 
								 | 
							
								            data: e.currentTarget.dataset.content
							 | 
						||
| 
								 | 
							
								          })
							 | 
						||
| 
								 | 
							
								      })
							 | 
						||
| 
								 | 
							
								    }
							 | 
						||
| 
								 | 
							
								  }
							 | 
						||
| 
								 | 
							
								}
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								if (config.showLanguageName) {
							 | 
						||
| 
								 | 
							
								  build.style = (build.style || '') +
							 | 
						||
| 
								 | 
							
								    `.hl-language {
							 | 
						||
| 
								 | 
							
								  font-size: 12px;
							 | 
						||
| 
								 | 
							
								  font-weight: 600;
							 | 
						||
| 
								 | 
							
								  position: absolute;
							 | 
						||
| 
								 | 
							
								  right: 8px;
							 | 
						||
| 
								 | 
							
								  text-align: right;
							 | 
						||
| 
								 | 
							
								  top: 3px;
							 | 
						||
| 
								 | 
							
								}
							 | 
						||
| 
								 | 
							
								.hl-pre {
							 | 
						||
| 
								 | 
							
								  padding-top: 1.5em;
							 | 
						||
| 
								 | 
							
								}`
							 | 
						||
| 
								 | 
							
								}
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								if (config.showLineNumber) {
							 | 
						||
| 
								 | 
							
								  build.style = (build.style || '') +
							 | 
						||
| 
								 | 
							
								    `.hl-pre {
							 | 
						||
| 
								 | 
							
								  font-size: 14px;
							 | 
						||
| 
								 | 
							
								  padding-left: 3.8em;
							 | 
						||
| 
								 | 
							
								  counter-reset: linenumber;
							 | 
						||
| 
								 | 
							
								}
							 | 
						||
| 
								 | 
							
								.line-numbers-rows {
							 | 
						||
| 
								 | 
							
								  position: absolute;
							 | 
						||
| 
								 | 
							
								  pointer-events: none;
							 | 
						||
| 
								 | 
							
								  top: ${config.showLanguageName ? 1.5 : 1}em;
							 | 
						||
| 
								 | 
							
								  font-size: 100%;
							 | 
						||
| 
								 | 
							
								  left: 0;
							 | 
						||
| 
								 | 
							
								  width: 3em; /* works for line-numbers below 1000 lines */
							 | 
						||
| 
								 | 
							
								  letter-spacing: -1px;
							 | 
						||
| 
								 | 
							
								  border-right: 1px solid #999;
							 | 
						||
| 
								 | 
							
								  -webkit-user-select: none;
							 | 
						||
| 
								 | 
							
								  -moz-user-select: none;
							 | 
						||
| 
								 | 
							
								  -ms-user-select: none;
							 | 
						||
| 
								 | 
							
								  user-select: none;
							 | 
						||
| 
								 | 
							
								}
							 | 
						||
| 
								 | 
							
								.line-numbers-rows .span {
							 | 
						||
| 
								 | 
							
								  display: block;
							 | 
						||
| 
								 | 
							
								  counter-increment: linenumber;
							 | 
						||
| 
								 | 
							
								} 
							 | 
						||
| 
								 | 
							
								.line-numbers-rows .span:before {
							 | 
						||
| 
								 | 
							
								  content: counter(linenumber);
							 | 
						||
| 
								 | 
							
								  color: #999;
							 | 
						||
| 
								 | 
							
								  display: block;
							 | 
						||
| 
								 | 
							
								  padding-right: 0.8em;
							 | 
						||
| 
								 | 
							
								  text-align: right;
							 | 
						||
| 
								 | 
							
								}`
							 | 
						||
| 
								 | 
							
								}
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								module.exports = build
							 |