templates

package
v0.0.0-...-e61ee7f Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Dec 19, 2024 License: MIT Imports: 53 Imported by: 0

Documentation

Index

Constants

This section is empty.

Variables

View Source
var ErrTemplateNotInitialized = errors.New("template system is not initialized, check your log for errors")

Functions

func ActionContent2Commits

func ActionContent2Commits(act Actioner) *repository.PushCommits

ActionContent2Commits converts action content to push commits

func AssetFS

func AssetFS() *assetfs.LayeredFS

func AvatarHTML

func AvatarHTML(src string, size int, class, name string) template.HTML

AvatarHTML creates the HTML for an avatar

func BuiltinAssets

func BuiltinAssets() *assetfs.Layer

func CustomAssets

func CustomAssets() *assetfs.Layer

func HandleTemplateRenderingError

func HandleTemplateRenderingError(err error) string

func ListMailTemplateAssetNames

func ListMailTemplateAssetNames(assets *assetfs.LayeredFS) ([]string, error)

func ListWebTemplateAssetNames

func ListWebTemplateAssetNames(assets *assetfs.LayeredFS) ([]string, error)

func Mailer

Mailer provides the templates required for sending notification mails.

func NewFuncMap

func NewFuncMap() template.FuncMap

NewFuncMap returns functions for injecting to templates

func QueryBuild

func QueryBuild(a ...any) template.URL

QueryBuild builds a query string from a list of key-value pairs. It omits the nil and empty strings, but it doesn't omit other zero values, because the zero value of number types may have a meaning.

func ReloadHTMLTemplates

func ReloadHTMLTemplates() error

func SanitizeHTML

func SanitizeHTML(s string) template.HTML

SanitizeHTML sanitizes the input by pre-defined markdown rules

func TimeSince

func TimeSince(then any) template.HTML

TimeSince renders relative time HTML given a time

Types

type Actioner

type Actioner interface {
	GetOpType() activities_model.ActionType
	GetActUserName(ctx context.Context) string
	GetRepoUserName(ctx context.Context) string
	GetRepoName(ctx context.Context) string
	GetRepoPath(ctx context.Context) string
	GetRepoLink(ctx context.Context) string
	GetBranch() string
	GetContent() string
	GetCreate() time.Time
	GetIssueInfos() []string
}

Actioner describes an action

type AvatarUtils

type AvatarUtils struct {
	// contains filtered or unexported fields
}

func NewAvatarUtils

func NewAvatarUtils(ctx context.Context) *AvatarUtils

func (*AvatarUtils) Avatar

func (au *AvatarUtils) Avatar(item any, others ...any) template.HTML

Avatar renders user avatars. args: user, size (int), class (string)

func (*AvatarUtils) AvatarByAction

func (au *AvatarUtils) AvatarByAction(action *activities_model.Action, others ...any) template.HTML

AvatarByAction renders user avatars from action. args: action, size (int), class (string)

func (*AvatarUtils) AvatarByEmail

func (au *AvatarUtils) AvatarByEmail(email, name string, others ...any) template.HTML

AvatarByEmail renders avatars by email address. args: email, name, size (int), class (string)

type DateUtils

type DateUtils struct{}

func NewDateUtils

func NewDateUtils() *DateUtils

func (*DateUtils) AbsoluteLong

func (du *DateUtils) AbsoluteLong(time any) template.HTML

AbsoluteLong renders in "January 01, 2006" format

func (*DateUtils) AbsoluteShort

func (du *DateUtils) AbsoluteShort(time any) template.HTML

AbsoluteShort renders in "Jan 01, 2006" format

func (*DateUtils) FullTime

func (du *DateUtils) FullTime(time any) template.HTML

FullTime renders in "Jan 01, 2006 20:33:44" format

func (*DateUtils) ParseLegacy

func (du *DateUtils) ParseLegacy(datetime string) time.Time

ParseLegacy parses the datetime in legacy format, eg: "2016-01-02" in server's timezone. It shouldn't be used in new code. New code should use Time or TimeStamp as much as possible.

func (*DateUtils) TimeSince

func (du *DateUtils) TimeSince(time any) template.HTML

type HTMLRender

type HTMLRender struct {
	// contains filtered or unexported fields
}

func HTMLRenderer

func HTMLRenderer() *HTMLRender

HTMLRenderer init once and returns the globally shared html renderer

func (*HTMLRender) CompileTemplates

func (h *HTMLRender) CompileTemplates() error

func (*HTMLRender) HTML

func (h *HTMLRender) HTML(w io.Writer, status int, name string, data any, ctx context.Context) error

func (*HTMLRender) TemplateLookup

func (h *HTMLRender) TemplateLookup(name string, ctx context.Context) (TemplateExecutor, error)

type JsonUtils

type JsonUtils struct{} //nolint:revive

func NewJsonUtils

func NewJsonUtils() *JsonUtils

func (*JsonUtils) EncodeToString

func (su *JsonUtils) EncodeToString(v any) string

func (*JsonUtils) PrettyIndent

func (su *JsonUtils) PrettyIndent(s string) string

type RenderUtils

type RenderUtils struct {
	// contains filtered or unexported fields
}

func NewRenderUtils

func NewRenderUtils(ctx context.Context) *RenderUtils

func (*RenderUtils) MarkdownToHtml

func (ut *RenderUtils) MarkdownToHtml(input string) template.HTML

func (*RenderUtils) RenderCommitBody

func (ut *RenderUtils) RenderCommitBody(msg string, metas map[string]string) template.HTML

RenderCommitBody extracts the body of a commit message without its title.

func (*RenderUtils) RenderCommitMessage

func (ut *RenderUtils) RenderCommitMessage(msg string, metas map[string]string) template.HTML

RenderCommitMessage renders commit message with XSS-safe and special links.

func (*RenderUtils) RenderCommitMessageLinkSubject

func (ut *RenderUtils) RenderCommitMessageLinkSubject(msg, urlDefault string, metas map[string]string) template.HTML

RenderCommitMessageLinkSubject renders commit message as a XSS-safe link to the provided default url, handling for special links without email to links.

func (*RenderUtils) RenderEmoji

func (ut *RenderUtils) RenderEmoji(text string) template.HTML

RenderEmoji renders html text with emoji post processors

func (*RenderUtils) RenderIssueSimpleTitle

func (ut *RenderUtils) RenderIssueSimpleTitle(text string) template.HTML

RenderIssueSimpleTitle only renders with emoji and inline code block

func (*RenderUtils) RenderIssueTitle

func (ut *RenderUtils) RenderIssueTitle(text string, metas map[string]string) template.HTML

RenderIssueTitle renders issue/pull title with defined post processors

func (*RenderUtils) RenderLabel

func (ut *RenderUtils) RenderLabel(label *issues_model.Label) template.HTML

RenderLabel renders a label

func (*RenderUtils) RenderLabels

func (ut *RenderUtils) RenderLabels(labels []*issues_model.Label, repoLink string, issue *issues_model.Issue) template.HTML

type SliceUtils

type SliceUtils struct{}

func NewSliceUtils

func NewSliceUtils() *SliceUtils

func (*SliceUtils) Contains

func (su *SliceUtils) Contains(s, v any) bool

type StringUtils

type StringUtils struct{}

func NewStringUtils

func NewStringUtils() *StringUtils

func (*StringUtils) Contains

func (su *StringUtils) Contains(s, substr string) bool

func (*StringUtils) Cut

func (su *StringUtils) Cut(s, sep string) []any

func (*StringUtils) EllipsisString

func (su *StringUtils) EllipsisString(s string, maxLength int) string

func (*StringUtils) HasPrefix

func (su *StringUtils) HasPrefix(s, prefix string) bool

func (*StringUtils) Join

func (su *StringUtils) Join(a []string, sep string) string

func (*StringUtils) Split

func (su *StringUtils) Split(s, sep string) []string

func (*StringUtils) ToString

func (su *StringUtils) ToString(v any) string

func (*StringUtils) ToUpper

func (su *StringUtils) ToUpper(s string) string

func (*StringUtils) TrimPrefix

func (su *StringUtils) TrimPrefix(s, prefix string) string

type TemplateExecutor

type TemplateExecutor scopedtmpl.TemplateExecutor

Directories

Path Synopsis

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL