|
@@ -222,6 +222,7 @@ BlazeComponent.extendComponent({
|
|
'operator-created': 'createdAt',
|
|
'operator-created': 'createdAt',
|
|
'operator-modified': 'modifiedAt',
|
|
'operator-modified': 'modifiedAt',
|
|
'operator-comment': 'comments',
|
|
'operator-comment': 'comments',
|
|
|
|
+ 'operator-has': 'has',
|
|
};
|
|
};
|
|
|
|
|
|
const predicates = {
|
|
const predicates = {
|
|
@@ -244,6 +245,11 @@ BlazeComponent.extendComponent({
|
|
'predicate-created': 'createdAt',
|
|
'predicate-created': 'createdAt',
|
|
'predicate-modified': 'modifiedAt',
|
|
'predicate-modified': 'modifiedAt',
|
|
},
|
|
},
|
|
|
|
+ has: {
|
|
|
|
+ 'predicate-description': 'description',
|
|
|
|
+ 'predicate-checklist': 'checklist',
|
|
|
|
+ 'predicate-attachment': 'attachment',
|
|
|
|
+ },
|
|
};
|
|
};
|
|
const predicateTranslations = {};
|
|
const predicateTranslations = {};
|
|
Object.entries(predicates).forEach(([category, catPreds]) => {
|
|
Object.entries(predicates).forEach(([category, catPreds]) => {
|
|
@@ -276,6 +282,7 @@ BlazeComponent.extendComponent({
|
|
createdAt: null,
|
|
createdAt: null,
|
|
modifiedAt: null,
|
|
modifiedAt: null,
|
|
comments: [],
|
|
comments: [],
|
|
|
|
+ has: [],
|
|
};
|
|
};
|
|
|
|
|
|
let text = '';
|
|
let text = '';
|
|
@@ -296,6 +303,7 @@ BlazeComponent.extendComponent({
|
|
} else {
|
|
} else {
|
|
op = m.groups.abbrev.toLowerCase();
|
|
op = m.groups.abbrev.toLowerCase();
|
|
}
|
|
}
|
|
|
|
+ // eslint-disable-next-line no-prototype-builtins
|
|
if (operatorMap.hasOwnProperty(op)) {
|
|
if (operatorMap.hasOwnProperty(op)) {
|
|
let value = m.groups.value;
|
|
let value = m.groups.value;
|
|
if (operatorMap[op] === 'labels') {
|
|
if (operatorMap[op] === 'labels') {
|
|
@@ -353,6 +361,15 @@ BlazeComponent.extendComponent({
|
|
} else {
|
|
} else {
|
|
value = predicateTranslations.status[value];
|
|
value = predicateTranslations.status[value];
|
|
}
|
|
}
|
|
|
|
+ } else if (operatorMap[op] === 'has') {
|
|
|
|
+ if (!predicateTranslations.has[value]) {
|
|
|
|
+ this.parsingErrors.push({
|
|
|
|
+ tag: 'operator-has-invalid',
|
|
|
|
+ value,
|
|
|
|
+ });
|
|
|
|
+ } else {
|
|
|
|
+ value = predicateTranslations.has[value];
|
|
|
|
+ }
|
|
}
|
|
}
|
|
if (Array.isArray(params[operatorMap[op]])) {
|
|
if (Array.isArray(params[operatorMap[op]])) {
|
|
params[operatorMap[op]].push(value);
|
|
params[operatorMap[op]].push(value);
|