refactor: unify tags and edges into single rels table
This commit is contained in:
@@ -27,10 +27,7 @@ var updateCmd = &cobra.Command{
|
||||
return
|
||||
}
|
||||
|
||||
input := service.UpdateInput{
|
||||
AddTags: append([]string{}, uAddTags...),
|
||||
RemoveTags: uRmTags,
|
||||
}
|
||||
var input service.UpdateInput
|
||||
|
||||
if cmd.Flags().Changed("title") {
|
||||
input.Title = &uTitle
|
||||
@@ -46,15 +43,23 @@ var updateCmd = &cobra.Command{
|
||||
input.DueDate = &empty
|
||||
}
|
||||
|
||||
// Shorthand flags expand to tags or rels.
|
||||
// --tag / --tag-remove are aliases for --rel / --rel-remove with no target.
|
||||
for _, tag := range uAddTags {
|
||||
input.AddRels = append(input.AddRels, service.RelInput{Type: models.RelType(tag), Target: ""})
|
||||
}
|
||||
for _, tag := range uRmTags {
|
||||
input.RemoveRels = append(input.RemoveRels, service.RelInput{Type: models.RelType(tag), Target: ""})
|
||||
}
|
||||
|
||||
// Shorthand flags expand to property rels or edge rels.
|
||||
if cmd.Flags().Changed("type") {
|
||||
input.AddTags = append(input.AddTags, "_type::"+uType)
|
||||
input.AddRels = append(input.AddRels, service.RelInput{Type: models.RelType("_type::" + uType), Target: ""})
|
||||
}
|
||||
if cmd.Flags().Changed("status") {
|
||||
input.AddTags = append(input.AddTags, "_status::"+uStatus)
|
||||
input.AddRels = append(input.AddRels, service.RelInput{Type: models.RelType("_status::" + uStatus), Target: ""})
|
||||
}
|
||||
if cmd.Flags().Changed("prio") {
|
||||
input.AddTags = append(input.AddTags, "_prio::"+uPrio)
|
||||
input.AddRels = append(input.AddRels, service.RelInput{Type: models.RelType("_prio::" + uPrio), Target: ""})
|
||||
}
|
||||
if cmd.Flags().Changed("namespace") {
|
||||
input.AddRels = append(input.AddRels, service.RelInput{Type: models.RelInNamespace, Target: uNamespace})
|
||||
@@ -101,8 +106,8 @@ func init() {
|
||||
f.StringVar(&uType, "type", "", "node type")
|
||||
f.StringVar(&uNamespace, "namespace", "", "namespace name or ID")
|
||||
f.StringVar(&uAssignee, "assignee", "", "assignee username or ID")
|
||||
f.StringArrayVar(&uAddTags, "tag", nil, "add tags")
|
||||
f.StringArrayVar(&uRmTags, "tag-remove", nil, "remove tags")
|
||||
f.StringArrayVar(&uAddRels, "rel", nil, "add relations (type:target)")
|
||||
f.StringArrayVar(&uRmRels, "rel-remove", nil, "remove relations (type:target)")
|
||||
f.StringArrayVar(&uAddTags, "tag", nil, "add label tag (alias for --rel tagname)")
|
||||
f.StringArrayVar(&uRmTags, "tag-remove", nil, "remove label tag")
|
||||
f.StringArrayVar(&uAddRels, "rel", nil, "add relation (prefix::value or relname:target)")
|
||||
f.StringArrayVar(&uRmRels, "rel-remove", nil, "remove relation (prefix::value or relname:target)")
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user