* Server-side syntax hilighting for all code This PR does a few things: * Remove all traces of highlight.js * Use chroma library to provide fast syntax hilighting directly on the server * Provide syntax hilighting for diffs * Re-style both unified and split diffs views * Add custom syntax hilighting styling for both regular and arc-green Fixes #7729 Fixes #10157 Fixes #11825 Fixes #7728 Fixes #3872 Fixes #3682 And perhaps gets closer to #9553 * fix line marker * fix repo search * Fix single line select * properly load settings * npm uninstall highlight.js * review suggestion * code review * forgot to call function * fix test * Apply suggestions from code review suggestions from @silverwind thanks Co-authored-by: silverwind <me@silverwind.io> * code review * copy/paste error * Use const for highlight size limit * Update web_src/less/_repository.less Co-authored-by: Lauris BH <lauris@nix.lv> * update size limit to 1MB and other styling tweaks * fix highlighting for certain diff sections * fix test * add worker back as suggested Co-authored-by: silverwind <me@silverwind.io> Co-authored-by: Lauris BH <lauris@nix.lv>
		
			
				
	
	
		
			52 lines
		
	
	
		
			2.0 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			52 lines
		
	
	
		
			2.0 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| package styles
 | |
| 
 | |
| import (
 | |
| 	"github.com/alecthomas/chroma"
 | |
| )
 | |
| 
 | |
| // Friendly style.
 | |
| var Friendly = Register(chroma.MustNewStyle("friendly", chroma.StyleEntries{
 | |
| 	chroma.TextWhitespace:        "#bbbbbb",
 | |
| 	chroma.Comment:               "italic #60a0b0",
 | |
| 	chroma.CommentPreproc:        "noitalic #007020",
 | |
| 	chroma.CommentSpecial:        "noitalic bg:#fff0f0",
 | |
| 	chroma.Keyword:               "bold #007020",
 | |
| 	chroma.KeywordPseudo:         "nobold",
 | |
| 	chroma.KeywordType:           "nobold #902000",
 | |
| 	chroma.Operator:              "#666666",
 | |
| 	chroma.OperatorWord:          "bold #007020",
 | |
| 	chroma.NameBuiltin:           "#007020",
 | |
| 	chroma.NameFunction:          "#06287e",
 | |
| 	chroma.NameClass:             "bold #0e84b5",
 | |
| 	chroma.NameNamespace:         "bold #0e84b5",
 | |
| 	chroma.NameException:         "#007020",
 | |
| 	chroma.NameVariable:          "#bb60d5",
 | |
| 	chroma.NameConstant:          "#60add5",
 | |
| 	chroma.NameLabel:             "bold #002070",
 | |
| 	chroma.NameEntity:            "bold #d55537",
 | |
| 	chroma.NameAttribute:         "#4070a0",
 | |
| 	chroma.NameTag:               "bold #062873",
 | |
| 	chroma.NameDecorator:         "bold #555555",
 | |
| 	chroma.LiteralString:         "#4070a0",
 | |
| 	chroma.LiteralStringDoc:      "italic",
 | |
| 	chroma.LiteralStringInterpol: "italic #70a0d0",
 | |
| 	chroma.LiteralStringEscape:   "bold #4070a0",
 | |
| 	chroma.LiteralStringRegex:    "#235388",
 | |
| 	chroma.LiteralStringSymbol:   "#517918",
 | |
| 	chroma.LiteralStringOther:    "#c65d09",
 | |
| 	chroma.LiteralNumber:         "#40a070",
 | |
| 	chroma.GenericHeading:        "bold #000080",
 | |
| 	chroma.GenericSubheading:     "bold #800080",
 | |
| 	chroma.GenericDeleted:        "#A00000",
 | |
| 	chroma.GenericInserted:       "#00A000",
 | |
| 	chroma.GenericError:          "#FF0000",
 | |
| 	chroma.GenericEmph:           "italic",
 | |
| 	chroma.GenericStrong:         "bold",
 | |
| 	chroma.GenericPrompt:         "bold #c65d09",
 | |
| 	chroma.GenericOutput:         "#888",
 | |
| 	chroma.GenericTraceback:      "#04D",
 | |
| 	chroma.GenericUnderline:      "underline",
 | |
| 	chroma.Error:                 "border:#FF0000",
 | |
| 	chroma.Background:            " bg:#f0f0f0",
 | |
| }))
 |