feature (redesign): file manager menu buttons after rewrite

This commit is contained in:
MickaelK 2024-03-11 19:39:29 +11:00
parent a8e3167287
commit 9e5d97800a
6 changed files with 26 additions and 20 deletions

View file

@ -98,7 +98,7 @@ body.touch-yes [is="component-breadcrumb"] .ul span::-webkit-scrollbar-thumb {
}
body.touch-no .component_path-element-wrapper a.label:hover {
background: rgba(0, 0, 0, 0.05);
background: var(--border);
}
body.touch-no .component_path-element-wrapper a.label:hover span.title {
opacity: 1;

View file

@ -55,7 +55,7 @@
max-width: 815px;
}
.component_filemanager_shell [data-bind="sidebar"].hidden ~ div > [data-bind="filemanager-children"] {
background: var(--bg-color);
background: rgba(100,100,100,.05);
}
.component_filemanager_shell [data-bind="filemanager-children"] .container,

View file

@ -27,6 +27,8 @@ class Icon extends window.HTMLElement {
return "";
case "eye":
return "";
case "close":
return ""
case "loading":
return "";
}

View file

@ -4,4 +4,6 @@ export function CSS(baseURL: string, ...arrayOfFilenames: string[]): Promise<str
export function loadSingleCSS(baseURL: string, filename: string): Promise<string>;
export function init(): Promise<void>;
export function loadJS(baseURL: string, path: string, opts?: object): Promise<string>;
export function init(): Promise<void>;

View file

@ -1,16 +1,16 @@
/* General design */
[is="component_submenu"] {
margin-top: 20px;
margin-top: 10px;
position: sticky;
top: 0;
z-index: 3;
padding: 8px 0;
padding: 5px 0;
backdrop-filter: blur(10px);
transition: 0.2s ease box-shadow;
}
.scrolling [is="component_submenu"] {
box-shadow: 0 5px 10px rgba(100,100,100,.05);
background: rgba(0,0,0,0.01);
background: rgba(245,245,245,0.75);
}
[is="component_submenu"] .component_submenu {
display: flex;
@ -19,10 +19,10 @@
}
[is="component_submenu"] .component_submenu .action button {
padding: 6px 10px;
font-size: 0.8rem;
background: transparent;
color: #626469fa;
text-transform: uppercase;
font-size: 0.8rem;
color: var(--light);
letter-spacing: 0;
border-radius: 5px;
}
@ -32,7 +32,6 @@
margin-left: -3px;
margin-right: -3px;
}
[is="component_submenu"] .component_submenu .action.left button,
[is="component_submenu"] .component_submenu .action.right:hover{
background: var(--border);
}
@ -61,7 +60,6 @@
background: var(--bg-color);
}
/* search */
/* img[alt="search"]:hover ~ input { */
/* background: red; */

View file

@ -6,6 +6,7 @@ import { qs } from "../../lib/dom.js";
import { getSelection$, clearSelection } from "./model_files.js";
import "../../components/dropdown.js";
import "../../components/icon.js";
export default async function(render) {
const $page = createElement(`<div class="component_submenu container"></div>`);
@ -22,12 +23,14 @@ export default async function(render) {
));
onDestroy(() => clearSelection());
// feature1: layout base case
effect(getSelection$().pipe(
rxjs.filter((selections) => selections.length === 0),
rxjs.mapTo(createFragment(`
rxjs.map(() => createFragment(`
<div class="action left no-select" style="margin-left:2px;">
<button>New File</button>
<button>New Folder</button>
<button data-action="new-file">New File</button>
<button data-action="new-folder">New Folder</button>
</div>
<div class="action right no-select" style="margin-right:2px;">
<button>
@ -54,21 +57,22 @@ export default async function(render) {
applyMutation($page, "replaceChildren"),
));
// feature2: update when selection is preset
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>
<button data-action="download">Download</button>
<button data-action="share">Share</button>
<button data-action="embed">Embed</button>
<button data-action="tag">Tag</button>
<button data-action="rename">Rename</button>
<button data-action="delete">Delete</button>
</div>
<div class="action right">
<button data-bind="clear">
${selections.length} x
${selections.length} <component-icon name="close"></component-icon>
</button>
</div>
`)),