mirror of
https://github.com/squidfunk/mkdocs-material.git
synced 2024-11-24 23:50:13 +01:00
Moved source integration into patches
This commit is contained in:
parent
ae05805124
commit
a6bc272778
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
1
material/assets/javascripts/bundle.4a3df536.min.js.map
Normal file
1
material/assets/javascripts/bundle.4a3df536.min.js.map
Normal file
File diff suppressed because one or more lines are too long
@ -1,6 +1,6 @@
|
|||||||
{
|
{
|
||||||
"assets/javascripts/bundle.js": "assets/javascripts/bundle.4120b2e2.min.js",
|
"assets/javascripts/bundle.js": "assets/javascripts/bundle.4a3df536.min.js",
|
||||||
"assets/javascripts/bundle.js.map": "assets/javascripts/bundle.4120b2e2.min.js.map",
|
"assets/javascripts/bundle.js.map": "assets/javascripts/bundle.4a3df536.min.js.map",
|
||||||
"assets/javascripts/worker/packer.js": "assets/javascripts/worker/packer.c14659e8.min.js",
|
"assets/javascripts/worker/packer.js": "assets/javascripts/worker/packer.c14659e8.min.js",
|
||||||
"assets/javascripts/worker/packer.js.map": "assets/javascripts/worker/packer.c14659e8.min.js.map",
|
"assets/javascripts/worker/packer.js.map": "assets/javascripts/worker/packer.c14659e8.min.js.map",
|
||||||
"assets/javascripts/worker/search.js": "assets/javascripts/worker/search.0a5433f7.min.js",
|
"assets/javascripts/worker/search.js": "assets/javascripts/worker/search.0a5433f7.min.js",
|
||||||
|
@ -190,7 +190,7 @@
|
|||||||
{% endblock %}
|
{% endblock %}
|
||||||
</div>
|
</div>
|
||||||
{% block scripts %}
|
{% block scripts %}
|
||||||
<script src="{{ 'assets/javascripts/bundle.4120b2e2.min.js' | url }}"></script>
|
<script src="{{ 'assets/javascripts/bundle.4a3df536.min.js' | url }}"></script>
|
||||||
<script id="__lang" type="application/json">
|
<script id="__lang" type="application/json">
|
||||||
{%- set translations = {} -%}
|
{%- set translations = {} -%}
|
||||||
{%- for key in [
|
{%- for key in [
|
||||||
|
@ -20,8 +20,13 @@
|
|||||||
* IN THE SOFTWARE.
|
* IN THE SOFTWARE.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
import { Observable, OperatorFunction, pipe } from "rxjs"
|
import { NEVER, Observable, OperatorFunction, pipe } from "rxjs"
|
||||||
import { map, switchMap } from "rxjs/operators"
|
import {
|
||||||
|
catchError,
|
||||||
|
map,
|
||||||
|
shareReplay,
|
||||||
|
switchMap
|
||||||
|
} from "rxjs/operators"
|
||||||
|
|
||||||
import {
|
import {
|
||||||
Header,
|
Header,
|
||||||
@ -68,7 +73,9 @@ export function mountHeaderTitle(
|
|||||||
map(({ offset: { y } }) => y >= headline.offsetHeight),
|
map(({ offset: { y } }) => y >= headline.offsetHeight),
|
||||||
paintHeaderTitle(el)
|
paintHeaderTitle(el)
|
||||||
)
|
)
|
||||||
)
|
),
|
||||||
|
shareReplay(1),
|
||||||
|
catchError(() => NEVER)
|
||||||
)
|
)
|
||||||
)
|
)
|
||||||
)
|
)
|
||||||
|
@ -73,9 +73,13 @@ import {
|
|||||||
mountHeaderTitle
|
mountHeaderTitle
|
||||||
} from "components"
|
} from "components"
|
||||||
import { setupClipboard } from "./integrations/clipboard"
|
import { setupClipboard } from "./integrations/clipboard"
|
||||||
import { patchTables, patchDetails, patchScrollfix } from "patches"
|
import {
|
||||||
|
patchTables,
|
||||||
|
patchDetails,
|
||||||
|
patchScrollfix,
|
||||||
|
patchSource
|
||||||
|
} from "patches"
|
||||||
import { takeIf, not, isConfig } from "utilities"
|
import { takeIf, not, isConfig } from "utilities"
|
||||||
import { setupSourceFacts } from "integrations/source"
|
|
||||||
import { renderDialog } from "templates/dialog"
|
import { renderDialog } from "templates/dialog"
|
||||||
|
|
||||||
/* ------------------------------------------------------------------------- */
|
/* ------------------------------------------------------------------------- */
|
||||||
@ -207,13 +211,12 @@ export function initialize(config: unknown) {
|
|||||||
|
|
||||||
patchTables({ document$ })
|
patchTables({ document$ })
|
||||||
patchDetails({ document$, hash$ })
|
patchDetails({ document$, hash$ })
|
||||||
|
patchSource({ document$ })
|
||||||
|
|
||||||
/* Force 1px scroll offset to trigger overflow scrolling */
|
/* Force 1px scroll offset to trigger overflow scrolling */
|
||||||
if (navigator.userAgent.match(/(iPad|iPhone|iPod)/g))
|
if (navigator.userAgent.match(/(iPad|iPhone|iPod)/g))
|
||||||
patchScrollfix({ document$ })
|
patchScrollfix({ document$ })
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
// TODO: general keyboard handler...
|
// TODO: general keyboard handler...
|
||||||
// put into main!?
|
// put into main!?
|
||||||
|
|
||||||
@ -301,10 +304,6 @@ export function initialize(config: unknown) {
|
|||||||
|
|
||||||
// build a notification component! feed txt into it...
|
// build a notification component! feed txt into it...
|
||||||
|
|
||||||
// TODO: WIP repo rendering
|
|
||||||
setupSourceFacts({ document$ })
|
|
||||||
.subscribe()
|
|
||||||
|
|
||||||
/* ----------------------------------------------------------------------- */
|
/* ----------------------------------------------------------------------- */
|
||||||
|
|
||||||
const state = {
|
const state = {
|
||||||
|
@ -22,7 +22,7 @@
|
|||||||
|
|
||||||
import * as ClipboardJS from "clipboard"
|
import * as ClipboardJS from "clipboard"
|
||||||
import { NEVER, Observable, fromEventPattern } from "rxjs"
|
import { NEVER, Observable, fromEventPattern } from "rxjs"
|
||||||
import { shareReplay, switchMap, tap } from "rxjs/operators"
|
import { shareReplay } from "rxjs/operators"
|
||||||
|
|
||||||
import { getElements } from "observables"
|
import { getElements } from "observables"
|
||||||
import { renderClipboard } from "templates"
|
import { renderClipboard } from "templates"
|
||||||
@ -55,30 +55,26 @@ interface SetupOptions {
|
|||||||
export function setupClipboard(
|
export function setupClipboard(
|
||||||
{ document$ }: SetupOptions
|
{ document$ }: SetupOptions
|
||||||
): Observable<ClipboardJS.Event> {
|
): Observable<ClipboardJS.Event> {
|
||||||
if (ClipboardJS.isSupported()) {
|
if (!ClipboardJS.isSupported())
|
||||||
return document$
|
return NEVER
|
||||||
.pipe(
|
|
||||||
|
|
||||||
/* Inject 'copy-to-clipboard' buttons */
|
/* Inject 'copy-to-clipboard' buttons */
|
||||||
tap(() => {
|
document$
|
||||||
|
.subscribe(() => {
|
||||||
const blocks = getElements("pre > code")
|
const blocks = getElements("pre > code")
|
||||||
for (const [index, block] of blocks.entries()) {
|
for (const [index, block] of blocks.entries()) {
|
||||||
const parent = block.parentElement!
|
const parent = block.parentElement!
|
||||||
parent.id = `__code_${index}`
|
parent.id = `__code_${index}`
|
||||||
parent.insertBefore(renderClipboard(parent.id), block)
|
parent.insertBefore(renderClipboard(parent.id), block)
|
||||||
}
|
}
|
||||||
}),
|
})
|
||||||
|
|
||||||
/* Initialize and setup clipboard */
|
/* Initialize and setup clipboard */
|
||||||
switchMap(() => {
|
|
||||||
return fromEventPattern<ClipboardJS.Event>(next => {
|
return fromEventPattern<ClipboardJS.Event>(next => {
|
||||||
const clipboard = new ClipboardJS(".md-clipboard")
|
const clipboard = new ClipboardJS(".md-clipboard")
|
||||||
clipboard.on("success", next)
|
clipboard.on("success", next)
|
||||||
})
|
})
|
||||||
}),
|
.pipe(
|
||||||
shareReplay(1)
|
shareReplay(1)
|
||||||
)
|
)
|
||||||
} else {
|
|
||||||
return NEVER
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
@ -22,4 +22,5 @@
|
|||||||
|
|
||||||
export * from "./details"
|
export * from "./details"
|
||||||
export * from "./scrollfix"
|
export * from "./scrollfix"
|
||||||
|
export * from "./source"
|
||||||
export * from "./table"
|
export * from "./table"
|
||||||
|
@ -20,13 +20,13 @@
|
|||||||
* IN THE SOFTWARE.
|
* IN THE SOFTWARE.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
import { NEVER, Observable, of } from "rxjs"
|
import { NEVER, Observable } from "rxjs"
|
||||||
import { switchMap, tap } from "rxjs/operators"
|
import { catchError, filter, switchMap } from "rxjs/operators"
|
||||||
|
|
||||||
import { getElement, getElements } from "observables"
|
import { getElementOrThrow, getElements } from "observables"
|
||||||
import { renderSource } from "templates"
|
import { renderSource } from "templates"
|
||||||
|
import { cache, hash } from "utilities"
|
||||||
|
|
||||||
import { cache } from "utilities"
|
|
||||||
import { fetchSourceFactsFromGitHub } from "./github"
|
import { fetchSourceFactsFromGitHub } from "./github"
|
||||||
import { fetchSourceFactsFromGitLab } from "./gitlab"
|
import { fetchSourceFactsFromGitLab } from "./gitlab"
|
||||||
|
|
||||||
@ -79,69 +79,38 @@ function fetchSourceFacts(
|
|||||||
|
|
||||||
/* Everything else */
|
/* Everything else */
|
||||||
default:
|
default:
|
||||||
return of([])
|
return NEVER
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// provide a function to set a unique key?
|
|
||||||
|
|
||||||
/* ----------------------------------------------------------------------------
|
/* ----------------------------------------------------------------------------
|
||||||
* Functions
|
* Functions
|
||||||
* ------------------------------------------------------------------------- */
|
* ------------------------------------------------------------------------- */
|
||||||
|
|
||||||
// TODO: this doesnt belong here...
|
|
||||||
|
|
||||||
// cache type.. session or local storage...
|
|
||||||
// subscribe to observable and cache automatically
|
|
||||||
|
|
||||||
// withCache or useCache
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Setup source facts
|
* Patch elements containing repository information
|
||||||
|
*
|
||||||
|
* This function will retrieve the URL from the repository link and try to
|
||||||
|
* query data from integrated source code platforms like GitHub or GitLab.
|
||||||
*
|
*
|
||||||
* @param options - Options
|
* @param options - Options
|
||||||
*
|
|
||||||
* @return Source facts observable
|
|
||||||
*/
|
*/
|
||||||
export function setupSourceFacts(
|
export function patchSource(
|
||||||
{ document$ }: SetupOptions
|
{ document$ }: SetupOptions
|
||||||
): Observable<any> {
|
): void {
|
||||||
return document$
|
document$
|
||||||
.pipe(
|
.pipe(
|
||||||
switchMap(() => cache("repository", () => {
|
switchMap(() => {
|
||||||
tap(console.log)
|
const el = getElementOrThrow<HTMLAnchorElement>(".md-source[href]")
|
||||||
const el = getElement<HTMLAnchorElement>(".md-source[href]") // TODO: useElement( document$ ) ? doesnt emit if no result
|
return cache(`${hash(el.href)}`, () => fetchSourceFacts(el.href))
|
||||||
if (!el) {
|
}),
|
||||||
return NEVER
|
filter(facts => !!facts.length),
|
||||||
} else {
|
catchError(() => NEVER)
|
||||||
// TODO: hash should be calculated from el.href
|
|
||||||
return fetchSourceFacts(el.href)
|
|
||||||
}
|
|
||||||
})),
|
|
||||||
|
|
||||||
tap(facts => {
|
|
||||||
console.log(facts)
|
|
||||||
if (facts.length) {
|
|
||||||
const sources = getElements(".md-source__repository")
|
|
||||||
sources.forEach(repo => {
|
|
||||||
repo.dataset.mdState = "done"
|
|
||||||
repo.appendChild(renderSource(facts))
|
|
||||||
})
|
|
||||||
}
|
|
||||||
})
|
|
||||||
// TODO: use URL? to dinstinguish
|
|
||||||
)
|
)
|
||||||
|
.subscribe(facts => {
|
||||||
|
for (const el of getElements(".md-source__repository")) {
|
||||||
|
el.setAttribute("data-md-state", "done")
|
||||||
|
el.appendChild(renderSource(facts))
|
||||||
|
}
|
||||||
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
// /**
|
|
||||||
// * Only emit a value if it is non-empty
|
|
||||||
// *
|
|
||||||
// * @template T - Value type
|
|
||||||
// *
|
|
||||||
// * @return Operator function
|
|
||||||
// */
|
|
||||||
// export function exists<T>(): OperatorFunction<T, NonNullable<T>> {
|
|
||||||
// return pipe(
|
|
||||||
// switchMap(value => !!value ? NEVER : of(value as NonNullable<T>))
|
|
||||||
// )
|
|
||||||
// }
|
|
Loading…
Reference in New Issue
Block a user