mirror of
https://github.com/mickael-kerjean/filestash.git
synced 2025-10-29 00:55:51 +08:00
87 lines
5.7 KiB
JavaScript
87 lines
5.7 KiB
JavaScript
import { onDestroy, createElement, createFragment } from "../../lib/skeleton/index.js";
|
|
import rxjs, { effect, applyMutation, onClick } from "../../lib/rx.js";
|
|
import { animate } from "../../lib/animate.js";
|
|
import { loadCSS } from "../../helpers/loader.js";
|
|
import { qs } from "../../lib/dom.js";
|
|
import { getSelection$, clearSelection } from "./model_files.js";
|
|
|
|
import "../../components/dropdown.js";
|
|
|
|
export default async function(render) {
|
|
const $page = createElement(`<div class="component_submenu container"></div>`);
|
|
render($page);
|
|
|
|
const $scroll = $page.closest(".scroll-y");
|
|
effect(rxjs.fromEvent($scroll, "scroll", { passive: true }).pipe(
|
|
rxjs.map((e) => e.target.scrollTop > 30),
|
|
rxjs.distinctUntilChanged(),
|
|
rxjs.startWith(false),
|
|
rxjs.tap((scrolling) => scrolling
|
|
? $scroll.classList.add("scrolling")
|
|
: $scroll.classList.remove("scrolling")),
|
|
));
|
|
|
|
onDestroy(() => clearSelection());
|
|
effect(getSelection$().pipe(
|
|
rxjs.filter((selections) => selections.length === 0),
|
|
rxjs.mapTo(createFragment(`
|
|
<div class="action left no-select" style="margin-left:2px;">
|
|
<button>New File</button>
|
|
<button>New Folder</button>
|
|
</div>
|
|
<div class="action right no-select" style="margin-right:2px;">
|
|
<button>
|
|
<input style="
|
|
display: none;
|
|
background: transparent;
|
|
border: none;
|
|
border-bottom: 2px solid #e2e2e2;
|
|
margin-right: 10px;
|
|
color: var(--color);
|
|
font-size: 0.8rem;
|
|
">
|
|
<img class="component_icon" draggable="false" src="" alt="search" />
|
|
</button>
|
|
<button>
|
|
<img class="component_icon" draggable="false" src="" alt="list" />
|
|
</button>
|
|
<button>
|
|
<img class="component_icon" draggable="false" src="" alt="sort" />
|
|
</button>
|
|
<!--<div is="component-dropdown"></div>-->
|
|
</div>
|
|
`)),
|
|
applyMutation($page, "replaceChildren"),
|
|
));
|
|
|
|
effect(getSelection$().pipe(
|
|
rxjs.filter((selections) => selections.length > 0),
|
|
rxjs.tap((selections) => selections.length === 1 && animate($page)),
|
|
rxjs.map((selections) => createFragment(`
|
|
<div class="action left">
|
|
<button>Download</button>
|
|
<button>Share</button>
|
|
<button>Embed</button>
|
|
<button>Tag</button>
|
|
<button>Rename</button>
|
|
<button>Delete</button>
|
|
</div>
|
|
<div class="action right">
|
|
<button data-bind="clear">
|
|
${selections.length} x
|
|
</button>
|
|
</div>
|
|
`)),
|
|
applyMutation($page, "replaceChildren"),
|
|
rxjs.mergeMap((e) => rxjs.merge(
|
|
onClick(qs($page, `[data-bind="clear"]`)).pipe(
|
|
rxjs.tap(() => clearSelection()),
|
|
),
|
|
)),
|
|
));
|
|
}
|
|
|
|
export function init() {
|
|
return loadCSS(import.meta.url, "./ctrl_submenu.css");
|
|
}
|