af7ffaa279
* 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 KiB
Go
Vendored
52 lines
2 KiB
Go
Vendored
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",
|
|
}))
|