2022-06-17 09:01:34 -04:00
|
|
|
import Component from "@ember/component";
|
2020-09-04 07:23:11 -04:00
|
|
|
import I18n from "I18n";
|
2022-06-17 09:01:34 -04:00
|
|
|
import discourseComputed from "discourse-common/utils/decorators";
|
2022-01-26 09:13:05 -05:00
|
|
|
import Category from "discourse/models/category";
|
2022-05-13 13:43:37 -04:00
|
|
|
import { dasherize } from "@ember/string";
|
2022-06-17 09:01:34 -04:00
|
|
|
import { isEmpty } from "@ember/utils";
|
|
|
|
import { computed } from "@ember/object";
|
2015-07-14 19:49:23 -04:00
|
|
|
|
2015-07-14 19:01:38 -04:00
|
|
|
const layoutMap = {
|
2018-10-10 07:56:23 -04:00
|
|
|
int: "int",
|
|
|
|
bigint: "int",
|
|
|
|
boolean: "boolean",
|
|
|
|
string: "generic",
|
|
|
|
time: "generic",
|
|
|
|
date: "generic",
|
|
|
|
datetime: "generic",
|
|
|
|
double: "string",
|
|
|
|
user_id: "user_id",
|
|
|
|
post_id: "string",
|
|
|
|
topic_id: "generic",
|
|
|
|
category_id: "generic",
|
|
|
|
group_id: "generic",
|
|
|
|
badge_id: "generic",
|
|
|
|
int_list: "generic",
|
|
|
|
string_list: "generic",
|
2020-09-04 07:23:11 -04:00
|
|
|
user_list: "user_list",
|
2015-07-14 19:01:38 -04:00
|
|
|
};
|
|
|
|
|
|
|
|
function allowsInputTypeTime() {
|
|
|
|
try {
|
2018-10-10 07:56:23 -04:00
|
|
|
const inp = document.createElement("input");
|
|
|
|
inp.attributes.type = "time";
|
|
|
|
inp.attributes.type = "date";
|
2015-07-14 19:01:38 -04:00
|
|
|
return true;
|
|
|
|
} catch (e) {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-06-17 09:01:34 -04:00
|
|
|
export default Component.extend({
|
2018-10-10 07:56:23 -04:00
|
|
|
classNameBindings: ["valid:valid:invalid", ":param"],
|
2015-07-14 19:01:38 -04:00
|
|
|
|
2018-10-10 07:56:23 -04:00
|
|
|
boolTypes: [
|
|
|
|
{ name: I18n.t("explorer.types.bool.true"), id: "Y" },
|
|
|
|
{ name: I18n.t("explorer.types.bool.false"), id: "N" },
|
2020-09-04 07:23:11 -04:00
|
|
|
{ name: I18n.t("explorer.types.bool.null_"), id: "#null" },
|
2018-10-10 07:56:23 -04:00
|
|
|
],
|
2021-09-14 11:10:16 -04:00
|
|
|
initialValues: null,
|
|
|
|
|
|
|
|
init() {
|
|
|
|
this._super(...arguments);
|
|
|
|
|
|
|
|
if (this.initialValues && this.info.identifier in this.initialValues) {
|
|
|
|
this.set("value", this.initialValues[this.info.identifier]);
|
|
|
|
}
|
|
|
|
},
|
2015-07-14 19:01:38 -04:00
|
|
|
|
2022-06-17 09:01:34 -04:00
|
|
|
value: computed("params", "info.identifier", {
|
2016-11-09 11:58:18 -05:00
|
|
|
get() {
|
2019-07-16 06:46:32 -04:00
|
|
|
return this.params[this.get("info.identifier")];
|
2016-11-09 11:58:18 -05:00
|
|
|
},
|
|
|
|
set(key, value) {
|
2022-01-17 06:45:40 -05:00
|
|
|
this.params[this.get("info.identifier")] = value?.toString();
|
2016-11-09 11:58:18 -05:00
|
|
|
return value;
|
2020-09-04 07:23:11 -04:00
|
|
|
},
|
2016-11-09 11:58:18 -05:00
|
|
|
}),
|
2015-07-15 14:00:31 -04:00
|
|
|
|
2022-06-17 09:01:34 -04:00
|
|
|
valueBool: computed("params", "info.identifier", {
|
2016-11-09 11:58:18 -05:00
|
|
|
get() {
|
2019-07-16 06:46:32 -04:00
|
|
|
return this.params[this.get("info.identifier")] !== "false";
|
2016-11-09 11:58:18 -05:00
|
|
|
},
|
|
|
|
set(key, value) {
|
|
|
|
value = !!value;
|
2019-07-16 06:46:32 -04:00
|
|
|
this.params[this.get("info.identifier")] = value.toString();
|
2016-11-09 11:58:18 -05:00
|
|
|
return value;
|
2020-09-04 07:23:11 -04:00
|
|
|
},
|
2016-11-09 11:58:18 -05:00
|
|
|
}),
|
2015-07-14 19:01:38 -04:00
|
|
|
|
2022-06-17 09:01:34 -04:00
|
|
|
@discourseComputed("value", "info.type", "info.nullable")
|
2019-07-16 06:46:32 -04:00
|
|
|
valid(value, type, nullable) {
|
2022-06-17 09:01:34 -04:00
|
|
|
if (isEmpty(value)) {
|
2019-07-16 06:46:32 -04:00
|
|
|
return nullable;
|
2015-07-14 19:01:38 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
const intVal = parseInt(value, 10);
|
2018-10-10 07:56:23 -04:00
|
|
|
const intValid =
|
|
|
|
!isNaN(intVal) && intVal < 2147483648 && intVal > -2147483649;
|
2015-07-14 19:49:23 -04:00
|
|
|
const isPositiveInt = /^\d+$/.test(value);
|
2015-07-14 19:01:38 -04:00
|
|
|
switch (type) {
|
2018-10-10 07:56:23 -04:00
|
|
|
case "int":
|
2015-07-14 19:01:38 -04:00
|
|
|
return /^-?\d+$/.test(value) && intValid;
|
2018-10-10 07:56:23 -04:00
|
|
|
case "bigint":
|
2015-07-14 19:01:38 -04:00
|
|
|
return /^-?\d+$/.test(value) && !isNaN(intVal);
|
2018-10-10 07:56:23 -04:00
|
|
|
case "boolean":
|
2015-07-14 19:01:38 -04:00
|
|
|
return /^Y|N|#null|true|false/.test(value);
|
2018-10-10 07:56:23 -04:00
|
|
|
case "double":
|
|
|
|
return (
|
|
|
|
!isNaN(parseFloat(value)) ||
|
|
|
|
/^(-?)Inf(inity)?$/i.test(value) ||
|
|
|
|
/^(-?)NaN$/i.test(value)
|
|
|
|
);
|
|
|
|
case "int_list":
|
2020-09-04 07:23:11 -04:00
|
|
|
return value.split(",").every((i) => /^(-?\d+|null)$/.test(i.trim()));
|
2018-10-10 07:56:23 -04:00
|
|
|
case "post_id":
|
2015-07-14 19:49:23 -04:00
|
|
|
return isPositiveInt || /\d+\/\d+(\?u=.*)?$/.test(value);
|
2018-10-10 07:56:23 -04:00
|
|
|
case "category_id":
|
2022-05-13 13:43:37 -04:00
|
|
|
if (!isPositiveInt && value !== dasherize(value)) {
|
|
|
|
this.set("value", dasherize(value));
|
2015-07-14 19:49:23 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
if (isPositiveInt) {
|
2020-09-04 07:23:11 -04:00
|
|
|
return !!this.site.categories.find((c) => c.id === intVal);
|
2015-07-14 19:49:23 -04:00
|
|
|
} else if (/\//.test(value)) {
|
|
|
|
const match = /(.*)\/(.*)/.exec(value);
|
2020-09-22 11:11:41 -04:00
|
|
|
if (!match) {
|
|
|
|
return false;
|
|
|
|
}
|
2018-10-10 07:56:23 -04:00
|
|
|
const result = Category.findBySlug(
|
2022-05-13 13:43:37 -04:00
|
|
|
dasherize(match[2]),
|
|
|
|
dasherize(match[1])
|
2018-10-10 07:56:23 -04:00
|
|
|
);
|
2015-07-14 19:49:23 -04:00
|
|
|
return !!result;
|
|
|
|
} else {
|
2022-05-13 13:43:37 -04:00
|
|
|
return !!Category.findBySlug(dasherize(value));
|
2015-07-14 19:49:23 -04:00
|
|
|
}
|
2018-10-10 07:56:23 -04:00
|
|
|
case "group_id":
|
|
|
|
const groups = this.site.get("groups");
|
2015-07-14 19:49:23 -04:00
|
|
|
if (isPositiveInt) {
|
2020-09-04 07:23:11 -04:00
|
|
|
return !!groups.find((g) => g.id === intVal);
|
2015-07-14 19:49:23 -04:00
|
|
|
} else {
|
2020-09-04 07:23:11 -04:00
|
|
|
return !!groups.find((g) => g.name === value);
|
2015-07-14 19:49:23 -04:00
|
|
|
}
|
2015-07-14 19:01:38 -04:00
|
|
|
}
|
|
|
|
return true;
|
2019-07-16 06:46:32 -04:00
|
|
|
},
|
2015-07-14 19:01:38 -04:00
|
|
|
|
2022-06-17 09:01:34 -04:00
|
|
|
@discourseComputed("info.type")
|
2019-07-16 06:46:32 -04:00
|
|
|
layoutType(type) {
|
2019-07-16 07:15:27 -04:00
|
|
|
if ((type === "time" || type === "date") && !allowsInputTypeTime()) {
|
2015-07-14 19:01:38 -04:00
|
|
|
return "string";
|
|
|
|
}
|
|
|
|
if (layoutMap[type]) {
|
|
|
|
return layoutMap[type];
|
|
|
|
}
|
2018-10-10 07:56:23 -04:00
|
|
|
return "generic";
|
2019-07-16 06:46:32 -04:00
|
|
|
},
|
2015-07-14 19:01:38 -04:00
|
|
|
|
2022-06-17 09:01:34 -04:00
|
|
|
@discourseComputed("layoutType")
|
2019-07-16 06:46:32 -04:00
|
|
|
layoutName(layoutType) {
|
|
|
|
return `admin/components/q-params/${layoutType}`;
|
2020-09-04 07:23:11 -04:00
|
|
|
},
|
2015-07-14 19:01:38 -04:00
|
|
|
});
|