mirror of
https://github.com/xuthus83/pigallery2.git
synced 2025-01-14 14:43:17 +08:00
Improve blog inlining if no date was added #711
This commit is contained in:
parent
c81428ade1
commit
e85fa29672
@ -83,10 +83,10 @@ Start numbering with offset:
|
||||
57. foo
|
||||
1. bar
|
||||
|
||||
<!-- @pg-date 2015-06-12 -->
|
||||
<!-- @pg-date 2015-06-29 -->
|
||||
## Day 1
|
||||
|
||||
You can tag section in the `*.md` files with `<!-- @pg-date <ISO_DATE> -->`, like: `<!-- @pg-date 2015-06-12 -->` to attach them to a date.
|
||||
You can tag section in the `*.md` files with `<!-- @pg-date <ISO_DATE> -->`, like: `<!-- @pg-date 2015-06-29 -->` to attach them to a date.
|
||||
Then, if you group by date, they will show up at the assigned day.
|
||||
|
||||
That part of the markdown will be removed from the main markdown at the top and shown only at that day.
|
||||
|
@ -17,25 +17,25 @@ export class BlogService {
|
||||
private mdFilesFilterPipe: MDFilesFilterPipe) {
|
||||
|
||||
this.groupedMarkdowns = this.galleryService.sortedFilteredContent.pipe(
|
||||
mergeMap(async content => {
|
||||
if (!content) {
|
||||
return [];
|
||||
}
|
||||
const dates = content.mediaGroups.map(g => g.date)
|
||||
.filter(d => !!d).map(d => d.getTime());
|
||||
mergeMap(async content => {
|
||||
if (!content) {
|
||||
return [];
|
||||
}
|
||||
const dates = content.mediaGroups.map(g => g.date)
|
||||
.filter(d => !!d).map(d => d.getTime());
|
||||
|
||||
|
||||
let firstMedia = Number.MAX_SAFE_INTEGER;
|
||||
if (content.mediaGroups.length > 0) {
|
||||
firstMedia = content.mediaGroups[0].media.reduce((p, m) =>
|
||||
Math.min(m.metadata.creationDate, p), Number.MAX_SAFE_INTEGER);
|
||||
}
|
||||
let firstMedia = Number.MAX_SAFE_INTEGER;
|
||||
if (content.mediaGroups.length > 0) {
|
||||
firstMedia = content.mediaGroups[0].media.reduce((p, m) =>
|
||||
Math.min(m.metadata.creationDate, p), Number.MAX_SAFE_INTEGER);
|
||||
}
|
||||
|
||||
const files = this.mdFilesFilterPipe.transform(content.metaFile)
|
||||
.map(f => this.splitMarkDown(f, dates, firstMedia));
|
||||
const files = this.mdFilesFilterPipe.transform(content.metaFile)
|
||||
.map(f => this.splitMarkDown(f, dates, firstMedia));
|
||||
|
||||
return (await Promise.all(files)).flat();
|
||||
}), shareReplay(1));
|
||||
return (await Promise.all(files)).flat();
|
||||
}), shareReplay(1));
|
||||
}
|
||||
|
||||
private async splitMarkDown(file: MDFileDTO, dates: number[], firstMedia: number): Promise<GroupedMarkdown[]> {
|
||||
@ -45,10 +45,12 @@ export class BlogService {
|
||||
return [];
|
||||
}
|
||||
|
||||
// there is no date group by
|
||||
if (dates.length == 0) {
|
||||
return [{
|
||||
text: markdown,
|
||||
file: file,
|
||||
date: null,
|
||||
textShort: markdown.substring(0, 200)
|
||||
}];
|
||||
}
|
||||
@ -61,15 +63,8 @@ export class BlogService {
|
||||
const ret: GroupedMarkdown[] = [];
|
||||
const matches = Array.from(markdown.matchAll(splitterRgx));
|
||||
|
||||
if (matches.length == 0) {
|
||||
return [{
|
||||
text: markdown,
|
||||
file: file,
|
||||
textShort: markdown.substring(0, 200)
|
||||
}];
|
||||
}
|
||||
|
||||
const getDateGroup = (dateNum: number) => {
|
||||
const getDateGroup = (date: Date) => {
|
||||
const dateNum = Utils.makeUTCMidnight(date).getTime();
|
||||
let groupDate = dates.find((d, i) => i > dates.length - 1 ? false : dates[i + 1] > dateNum); //dates are sorted
|
||||
|
||||
// cant find the date. put to the last group (as it was later)
|
||||
@ -80,6 +75,16 @@ export class BlogService {
|
||||
};
|
||||
|
||||
|
||||
if (matches.length == 0) {
|
||||
return [{
|
||||
text: markdown,
|
||||
file: file,
|
||||
textShort: markdown.substring(0, 200),
|
||||
date: getDateGroup(new Date(file.date))
|
||||
}];
|
||||
}
|
||||
|
||||
|
||||
const baseText = markdown.substring(0, matches[0].index).trim();
|
||||
|
||||
// don't show empty
|
||||
@ -87,13 +92,14 @@ export class BlogService {
|
||||
if (file.date === firstMedia) {
|
||||
ret.push({
|
||||
text: baseText,
|
||||
file: file
|
||||
file: file,
|
||||
date: null
|
||||
});
|
||||
} else {
|
||||
ret.push({
|
||||
text: baseText,
|
||||
file: file,
|
||||
date: getDateGroup(file.date)
|
||||
date: getDateGroup(new Date(file.date))
|
||||
});
|
||||
}
|
||||
}
|
||||
@ -101,7 +107,7 @@ export class BlogService {
|
||||
for (let i = 0; i < matches.length; ++i) {
|
||||
const matchedStr = matches[i][0];
|
||||
// get UTC midnight date
|
||||
const dateNum = Utils.makeUTCMidnight(new Date(matchedStr.match(dateRgx)[0])).getTime();
|
||||
const dateNum = new Date(matchedStr.match(dateRgx)[0]);
|
||||
|
||||
const groupDate = getDateGroup(dateNum);
|
||||
|
||||
@ -130,13 +136,13 @@ export class BlogService {
|
||||
|
||||
public getMarkDown(file: FileDTO): Promise<string> {
|
||||
const filePath = Utils.concatUrls(
|
||||
file.directory.path,
|
||||
file.directory.name,
|
||||
file.name
|
||||
file.directory.path,
|
||||
file.directory.name,
|
||||
file.name
|
||||
);
|
||||
if (!this.cache[filePath]) {
|
||||
this.cache[filePath] = this.networkService.getText(
|
||||
'/gallery/content/' + filePath
|
||||
'/gallery/content/' + filePath
|
||||
);
|
||||
(this.cache[filePath] as Promise<string>).then((val: string) => {
|
||||
this.cache[filePath] = val;
|
||||
@ -148,7 +154,7 @@ export class BlogService {
|
||||
|
||||
|
||||
export interface GroupedMarkdown {
|
||||
date?: number;
|
||||
date: number | null;
|
||||
text: string;
|
||||
textShort?: string;
|
||||
file: FileDTO;
|
||||
|
Loading…
x
Reference in New Issue
Block a user