module Issue.Meta ( Meta (..), getMeta, ) where import Data.Text qualified as T import Issue (Issue (..)) import Issue.Tag (Tag, tagValue) data Meta = Meta { referencedBy :: [(Issue, Tag)] } deriving (Show) getMeta :: [Issue] -> Issue -> Meta getMeta issues issue = Meta { referencedBy = concatMap ( \issueOther -> let tagsRelevant = filter (\tag -> tagValue tag == fmap T.pack issue.id) issueOther.tags in map (\tag -> (issue, tag)) tagsRelevant ) issues }