mirror of
https://github.com/stashapp/stash.git
synced 2025-12-18 21:04:37 +03:00
Containing Group/Sub-Group relationships (#5105)
* Add UI support for setting containing groups * Show containing groups in group details panel * Move tag hierarchical filter code into separate type * Add depth to scene_count and add sub_group_count * Add sub-groups tab to groups page * Add containing groups to edit groups dialog * Show containing group description in sub-group view * Show group scene number in group scenes view * Add ability to drag move grid cards * Add sub group order option * Add reorder sub-groups interface * Separate page size selector component * Add interfaces to add and remove sub-groups to a group * Separate MultiSet components * Allow setting description while setting containing groups
This commit is contained in:
@@ -1,5 +1,5 @@
|
||||
import React from "react";
|
||||
import { useIntl } from "react-intl";
|
||||
import { IntlShape, useIntl } from "react-intl";
|
||||
|
||||
import * as GQL from "src/core/generated-graphql";
|
||||
import { Button, ButtonGroup } from "react-bootstrap";
|
||||
@@ -52,70 +52,96 @@ const Select: React.FC<IMultiSetProps> = (props) => {
|
||||
);
|
||||
};
|
||||
|
||||
export const MultiSet: React.FC<IMultiSetProps> = (props) => {
|
||||
const intl = useIntl();
|
||||
const modes = [
|
||||
GQL.BulkUpdateIdMode.Set,
|
||||
GQL.BulkUpdateIdMode.Add,
|
||||
GQL.BulkUpdateIdMode.Remove,
|
||||
];
|
||||
|
||||
function getModeText(mode: GQL.BulkUpdateIdMode) {
|
||||
switch (mode) {
|
||||
case GQL.BulkUpdateIdMode.Set:
|
||||
return intl.formatMessage({
|
||||
id: "actions.overwrite",
|
||||
defaultMessage: "Overwrite",
|
||||
});
|
||||
case GQL.BulkUpdateIdMode.Add:
|
||||
return intl.formatMessage({ id: "actions.add", defaultMessage: "Add" });
|
||||
case GQL.BulkUpdateIdMode.Remove:
|
||||
return intl.formatMessage({
|
||||
id: "actions.remove",
|
||||
defaultMessage: "Remove",
|
||||
});
|
||||
}
|
||||
function getModeText(intl: IntlShape, mode: GQL.BulkUpdateIdMode) {
|
||||
switch (mode) {
|
||||
case GQL.BulkUpdateIdMode.Set:
|
||||
return intl.formatMessage({
|
||||
id: "actions.overwrite",
|
||||
defaultMessage: "Overwrite",
|
||||
});
|
||||
case GQL.BulkUpdateIdMode.Add:
|
||||
return intl.formatMessage({ id: "actions.add", defaultMessage: "Add" });
|
||||
case GQL.BulkUpdateIdMode.Remove:
|
||||
return intl.formatMessage({
|
||||
id: "actions.remove",
|
||||
defaultMessage: "Remove",
|
||||
});
|
||||
}
|
||||
}
|
||||
|
||||
function onSetMode(mode: GQL.BulkUpdateIdMode) {
|
||||
if (mode === props.mode) {
|
||||
export const MultiSetModeButton: React.FC<{
|
||||
mode: GQL.BulkUpdateIdMode;
|
||||
active: boolean;
|
||||
onClick: () => void;
|
||||
disabled?: boolean;
|
||||
}> = ({ mode, active, onClick, disabled }) => {
|
||||
const intl = useIntl();
|
||||
|
||||
return (
|
||||
<Button
|
||||
key={mode}
|
||||
variant="primary"
|
||||
active={active}
|
||||
size="sm"
|
||||
onClick={onClick}
|
||||
disabled={disabled}
|
||||
>
|
||||
{getModeText(intl, mode)}
|
||||
</Button>
|
||||
);
|
||||
};
|
||||
|
||||
const modes = [
|
||||
GQL.BulkUpdateIdMode.Set,
|
||||
GQL.BulkUpdateIdMode.Add,
|
||||
GQL.BulkUpdateIdMode.Remove,
|
||||
];
|
||||
|
||||
export const MultiSetModeButtons: React.FC<{
|
||||
mode: GQL.BulkUpdateIdMode;
|
||||
onSetMode: (mode: GQL.BulkUpdateIdMode) => void;
|
||||
disabled?: boolean;
|
||||
}> = ({ mode, onSetMode, disabled }) => {
|
||||
return (
|
||||
<ButtonGroup className="button-group-above">
|
||||
{modes.map((m) => (
|
||||
<MultiSetModeButton
|
||||
key={m}
|
||||
mode={m}
|
||||
active={mode === m}
|
||||
onClick={() => onSetMode(m)}
|
||||
disabled={disabled}
|
||||
/>
|
||||
))}
|
||||
</ButtonGroup>
|
||||
);
|
||||
};
|
||||
|
||||
export const MultiSet: React.FC<IMultiSetProps> = (props) => {
|
||||
const { mode, onUpdate, existingIds } = props;
|
||||
|
||||
function onSetMode(m: GQL.BulkUpdateIdMode) {
|
||||
if (m === mode) {
|
||||
return;
|
||||
}
|
||||
|
||||
// if going to Set, set the existing ids
|
||||
if (mode === GQL.BulkUpdateIdMode.Set && props.existingIds) {
|
||||
props.onUpdate(props.existingIds);
|
||||
if (m === GQL.BulkUpdateIdMode.Set && existingIds) {
|
||||
onUpdate(existingIds);
|
||||
// if going from Set, wipe the ids
|
||||
} else if (
|
||||
mode !== GQL.BulkUpdateIdMode.Set &&
|
||||
props.mode === GQL.BulkUpdateIdMode.Set
|
||||
m !== GQL.BulkUpdateIdMode.Set &&
|
||||
mode === GQL.BulkUpdateIdMode.Set
|
||||
) {
|
||||
props.onUpdate([]);
|
||||
onUpdate([]);
|
||||
}
|
||||
|
||||
props.onSetMode(mode);
|
||||
}
|
||||
|
||||
function renderModeButton(mode: GQL.BulkUpdateIdMode) {
|
||||
return (
|
||||
<Button
|
||||
key={mode}
|
||||
variant="primary"
|
||||
active={props.mode === mode}
|
||||
size="sm"
|
||||
onClick={() => onSetMode(mode)}
|
||||
disabled={props.disabled}
|
||||
>
|
||||
{getModeText(mode)}
|
||||
</Button>
|
||||
);
|
||||
props.onSetMode(m);
|
||||
}
|
||||
|
||||
return (
|
||||
<div className="multi-set">
|
||||
<ButtonGroup className="button-group-above">
|
||||
{modes.map((m) => renderModeButton(m))}
|
||||
</ButtonGroup>
|
||||
<MultiSetModeButtons mode={mode} onSetMode={onSetMode} />
|
||||
<Select {...props} />
|
||||
</div>
|
||||
);
|
||||
|
||||
Reference in New Issue
Block a user