Add label list edit panel & add button on label list #19
@ -12,6 +12,7 @@ interface IAttrInputProps {
|
|||||||
value?: number | string;
|
value?: number | string;
|
||||||
isNumber?: boolean;
|
isNumber?: boolean;
|
||||||
maxLength?: number;
|
maxLength?: number;
|
||||||
|
minLength?: number;
|
||||||
max?: number;
|
max?: number;
|
||||||
min?: number;
|
min?: number;
|
||||||
step?: number;
|
step?: number;
|
||||||
@ -40,6 +41,11 @@ class AttrInput extends Component<IAttrInputProps> {
|
|||||||
return <Localization i18nKey="Input.Error.Length" options={{ num: maxLength.toString() }} />
|
return <Localization i18nKey="Input.Error.Length" options={{ num: maxLength.toString() }} />
|
||||||
}
|
}
|
||||||
|
|
||||||
|
const minLength = this.props.minLength ?? 1;
|
||||||
|
if (value.length < minLength) {
|
||||||
|
return <Localization i18nKey="Input.Error.Length.Less" options={{ num: minLength.toString() }} />
|
||||||
|
}
|
||||||
|
|
||||||
if (this.props.isNumber) {
|
if (this.props.isNumber) {
|
||||||
const praseNumber = (value as any) / 1;
|
const praseNumber = (value as any) / 1;
|
||||||
|
|
||||||
|
@ -63,14 +63,22 @@ div.light.label {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
div.dark.label:hover,
|
div.dark.label:hover {
|
||||||
div.dark.label.focus {
|
|
||||||
color: $lt-font-color-lvl2-dark;
|
color: $lt-font-color-lvl2-dark;
|
||||||
background-color: $lt-bg-color-lvl2-dark;
|
background-color: $lt-bg-color-lvl2-dark;
|
||||||
}
|
}
|
||||||
|
|
||||||
div.light.label:hover,
|
div.dark.label.focus {
|
||||||
div.light.label.focus {
|
color: $lt-font-color-lvl1-dark;
|
||||||
|
background-color: $lt-bg-color-lvl1-dark;
|
||||||
|
}
|
||||||
|
|
||||||
|
div.light.label:hover {
|
||||||
color: $lt-font-color-lvl2-light;
|
color: $lt-font-color-lvl2-light;
|
||||||
background-color: $lt-bg-color-lvl2-light;
|
background-color: $lt-bg-color-lvl2-light;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
div.light.label.focus {
|
||||||
|
color: $lt-font-color-lvl1-light;
|
||||||
|
background-color: $lt-bg-color-lvl1-light;
|
||||||
|
}
|
@ -38,9 +38,6 @@ class LabelList extends Component<ILabelListProps & IMixinSettingProps> {
|
|||||||
}
|
}
|
||||||
this.isDeleteClick = false;
|
this.isDeleteClick = false;
|
||||||
}}
|
}}
|
||||||
style={{
|
|
||||||
borderColor: isFocus ? colorCss : undefined
|
|
||||||
}}
|
|
||||||
>
|
>
|
||||||
<div className="label-color" style={{
|
<div className="label-color" style={{
|
||||||
backgroundColor: colorCss,
|
backgroundColor: colorCss,
|
||||||
|
@ -9,7 +9,9 @@ interface ITogglesInputProps {
|
|||||||
infoI18n?: AllI18nKeys;
|
infoI18n?: AllI18nKeys;
|
||||||
value?: boolean;
|
value?: boolean;
|
||||||
disable?: boolean;
|
disable?: boolean;
|
||||||
valueChange?: (color: boolean) => any;
|
onIconName?: string;
|
||||||
|
offIconName?: string;
|
||||||
|
valueChange?: (value: boolean) => any;
|
||||||
}
|
}
|
||||||
|
|
||||||
class TogglesInput extends Component<ITogglesInputProps> {
|
class TogglesInput extends Component<ITogglesInputProps> {
|
||||||
@ -33,9 +35,17 @@ class TogglesInput extends Component<ITogglesInputProps> {
|
|||||||
}
|
}
|
||||||
})}
|
})}
|
||||||
>
|
>
|
||||||
<Icon iconName="CheckMark" style={{
|
<Icon
|
||||||
display: this.props.value ? "inline-block" : "none"
|
iconName={
|
||||||
}}></Icon>
|
this.props.value ?
|
||||||
|
this.props.onIconName ?? "CheckMark" :
|
||||||
|
this.props.offIconName ?? undefined
|
||||||
|
}
|
||||||
|
style={{
|
||||||
|
display: this.props.value ? "inline-block" :
|
||||||
|
this.props.offIconName ? "inline-block" : "none"
|
||||||
|
}}
|
||||||
|
></Icon>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</Theme>
|
</Theme>
|
||||||
|
@ -32,6 +32,7 @@ interface IStatusEvent {
|
|||||||
objectChange: void;
|
objectChange: void;
|
||||||
labelChange: void;
|
labelChange: void;
|
||||||
rangeAttrChange: void;
|
rangeAttrChange: void;
|
||||||
|
labelAttrChange: void;
|
||||||
}
|
}
|
||||||
|
|
||||||
class Status extends Emitter<IStatusEvent> {
|
class Status extends Emitter<IStatusEvent> {
|
||||||
@ -120,6 +121,24 @@ class Status extends Emitter<IStatusEvent> {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 修改范围属性
|
||||||
|
*/
|
||||||
|
public changeLabelAttrib<K extends keyof Label>
|
||||||
|
(label: Label, key: K, val: Label[K]) {
|
||||||
|
let findLabel: Label | undefined;
|
||||||
|
for (let i = 0; i < this.model.labelPool.length; i++) {
|
||||||
|
if (this.model.labelPool[i].equal(label)) {
|
||||||
|
findLabel = this.model.labelPool[i];
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (findLabel) {
|
||||||
|
findLabel[key] = val;
|
||||||
|
this.emit("labelAttrChange");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 鼠标工具状态
|
* 鼠标工具状态
|
||||||
*/
|
*/
|
||||||
|
@ -23,6 +23,7 @@ const EN_US = {
|
|||||||
"Input.Error.Max": "Enter value must be less than {num}",
|
"Input.Error.Max": "Enter value must be less than {num}",
|
||||||
"Input.Error.Min": "Enter value must be greater than {num}",
|
"Input.Error.Min": "Enter value must be greater than {num}",
|
||||||
"Input.Error.Length": "The length of the input content must be less than {num}",
|
"Input.Error.Length": "The length of the input content must be less than {num}",
|
||||||
|
"Input.Error.Length.Less": "The length of the input content must be greater than {num}",
|
||||||
"Object.List.New.Group": "Group object {id}",
|
"Object.List.New.Group": "Group object {id}",
|
||||||
"Object.List.New.Range": "Range object {id}",
|
"Object.List.New.Range": "Range object {id}",
|
||||||
"Object.List.New.Label": "Label {id}",
|
"Object.List.New.Label": "Label {id}",
|
||||||
@ -49,6 +50,7 @@ const EN_US = {
|
|||||||
"Common.Attr.Key.Color": "Color",
|
"Common.Attr.Key.Color": "Color",
|
||||||
"Common.Attr.Key.Display": "Display",
|
"Common.Attr.Key.Display": "Display",
|
||||||
"Common.Attr.Key.Update": "Update",
|
"Common.Attr.Key.Update": "Update",
|
||||||
|
"Common.Attr.Key.Delete": "Delete",
|
||||||
"Common.Attr.Key.Error.Multiple": "Multiple values",
|
"Common.Attr.Key.Error.Multiple": "Multiple values",
|
||||||
"Panel.Info.Range.Details.Attr.Error.Not.Range": "Object is not a Range",
|
"Panel.Info.Range.Details.Attr.Error.Not.Range": "Object is not a Range",
|
||||||
"Panel.Info.Range.Details.Attr.Error.Unspecified": "Unspecified range object",
|
"Panel.Info.Range.Details.Attr.Error.Unspecified": "Unspecified range object",
|
||||||
|
@ -23,6 +23,7 @@ const ZH_CN = {
|
|||||||
"Input.Error.Max": "输入数值须小于 {number}",
|
"Input.Error.Max": "输入数值须小于 {number}",
|
||||||
"Input.Error.Min": "输入数值须大于 {number}",
|
"Input.Error.Min": "输入数值须大于 {number}",
|
||||||
"Input.Error.Length": "输入内容长度须小于 {number}",
|
"Input.Error.Length": "输入内容长度须小于 {number}",
|
||||||
|
"Input.Error.Length.Less": "输入内容长度须大于 {number}",
|
||||||
"Object.List.New.Group": "组对象 {id}",
|
"Object.List.New.Group": "组对象 {id}",
|
||||||
"Object.List.New.Range": "范围对象 {id}",
|
"Object.List.New.Range": "范围对象 {id}",
|
||||||
"Object.List.New.Label": "标签 {id}",
|
"Object.List.New.Label": "标签 {id}",
|
||||||
@ -49,6 +50,7 @@ const ZH_CN = {
|
|||||||
"Common.Attr.Key.Color": "颜色",
|
"Common.Attr.Key.Color": "颜色",
|
||||||
"Common.Attr.Key.Display": "显示",
|
"Common.Attr.Key.Display": "显示",
|
||||||
"Common.Attr.Key.Update": "更新",
|
"Common.Attr.Key.Update": "更新",
|
||||||
|
"Common.Attr.Key.Delete": "删除",
|
||||||
"Common.Attr.Key.Error.Multiple": "多重数值",
|
"Common.Attr.Key.Error.Multiple": "多重数值",
|
||||||
"Panel.Info.Range.Details.Attr.Error.Not.Range": "对象不是一个范围",
|
"Panel.Info.Range.Details.Attr.Error.Not.Range": "对象不是一个范围",
|
||||||
"Panel.Info.Range.Details.Attr.Error.Unspecified": "未指定范围对象",
|
"Panel.Info.Range.Details.Attr.Error.Unspecified": "未指定范围对象",
|
||||||
|
@ -4,37 +4,32 @@ import { useStatusWithEvent, IMixinStatusProps } from "@Context/Status";
|
|||||||
import { AllI18nKeys } from "@Component/Localization/Localization";
|
import { AllI18nKeys } from "@Component/Localization/Localization";
|
||||||
import { ErrorMessage } from "@Component/ErrorMessage/ErrorMessage";
|
import { ErrorMessage } from "@Component/ErrorMessage/ErrorMessage";
|
||||||
import { ColorInput } from "@Component/ColorInput/ColorInput";
|
import { ColorInput } from "@Component/ColorInput/ColorInput";
|
||||||
import "./LabelDetails.scss";
|
|
||||||
import { LabelList } from "@Component/LabelList/LabelList";
|
|
||||||
import { Label } from "@Model/Label";
|
import { Label } from "@Model/Label";
|
||||||
|
import { TogglesInput } from "@Component/TogglesInput/TogglesInput";
|
||||||
|
import "./LabelDetails.scss";
|
||||||
|
|
||||||
@useStatusWithEvent("focusLabelChange")
|
@useStatusWithEvent("focusLabelChange", "labelAttrChange", "labelChange")
|
||||||
class LabelDetails extends Component<IMixinStatusProps> {
|
class LabelDetails extends Component<IMixinStatusProps> {
|
||||||
|
|
||||||
public readonly AttrI18nKey: AllI18nKeys[] = [
|
|
||||||
"Common.Attr.Key.Display.Name",
|
|
||||||
"Common.Attr.Key.Color",
|
|
||||||
]
|
|
||||||
|
|
||||||
private renderFrom(label: Label) {
|
private renderFrom(label: Label) {
|
||||||
return <>
|
return <>
|
||||||
|
|
||||||
<LabelList
|
<AttrInput keyI18n="Common.Attr.Key.Display.Name" maxLength={15} value={label.name} valueChange={(value) => {
|
||||||
labels={[label]}
|
|
||||||
canDelete
|
|
||||||
deleteLabel={() => {
|
|
||||||
if (this.props.status) {
|
if (this.props.status) {
|
||||||
this.props.status.model.deleteLabel(label);
|
this.props.status.changeLabelAttrib(label, "name", value);
|
||||||
this.props.status.setLabelObject();
|
|
||||||
}
|
}
|
||||||
}}
|
}}/>
|
||||||
/>
|
|
||||||
|
|
||||||
<AttrInput keyI18n="Common.Attr.Key.Display.Name" maxLength={15} value={label.name}/>
|
|
||||||
|
|
||||||
<ColorInput keyI18n="Common.Attr.Key.Color" value={label.color} valueChange={(color) => {
|
<ColorInput keyI18n="Common.Attr.Key.Color" value={label.color} valueChange={(color) => {
|
||||||
if (this.props.status) {
|
if (this.props.status) {
|
||||||
|
this.props.status.changeLabelAttrib(label, "color", color);
|
||||||
|
}
|
||||||
|
}}/>
|
||||||
|
|
||||||
|
<TogglesInput keyI18n="Common.Attr.Key.Delete" onIconName="delete" offIconName="delete" valueChange={() => {
|
||||||
|
if (this.props.status) {
|
||||||
|
this.props.status.model.deleteLabel(label);
|
||||||
|
this.props.status.setLabelObject();
|
||||||
}
|
}
|
||||||
}}/>
|
}}/>
|
||||||
|
|
||||||
|
@ -10,7 +10,7 @@ interface ILabelListProps {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@useSetting
|
@useSetting
|
||||||
@useStatusWithEvent("labelChange", "focusLabelChange")
|
@useStatusWithEvent("labelChange", "focusLabelChange", "labelAttrChange")
|
||||||
class LabelList extends Component<ILabelListProps & IMixinStatusProps & IMixinSettingProps> {
|
class LabelList extends Component<ILabelListProps & IMixinStatusProps & IMixinSettingProps> {
|
||||||
|
|
||||||
private labelInnerClick: boolean = false;
|
private labelInnerClick: boolean = false;
|
||||||
|
Loading…
Reference in New Issue
Block a user