first commit
This commit is contained in:
900
wp-content/plugins/brizy/admin/static/js/rules.js
Normal file
900
wp-content/plugins/brizy/admin/static/js/rules.js
Normal file
@@ -0,0 +1,900 @@
|
||||
var h = hyperapp.h;
|
||||
|
||||
var RULE_TYPE_INCLUDE = 1;
|
||||
var RULE_TYPE_EXCLUDE = 2;
|
||||
|
||||
var RULE_POSTS = 1;
|
||||
var RULE_TAXONOMY = 2;
|
||||
var RULE_ARCHIVE = 4;
|
||||
var RULE_TEMPLATE = 8;
|
||||
var RULE_BRIZY_TEMPLATE = 16;
|
||||
var ANY_CHILD_TAXONOMY = 128;
|
||||
var WOO_PAGES = 256;
|
||||
var RULE_DATE_ARCHIVE = 512;
|
||||
var RULE_YEAR_ARCHIVE = 1024;
|
||||
var RULE_MONTH_ARCHIVE = 2048;
|
||||
var RULE_DAY_ARCHIVE = 4096;
|
||||
|
||||
var defaultTemplateType = Brizy_Admin_Rules.templateType !== '' ? Brizy_Admin_Rules.templateType : 'single';
|
||||
var defaultAppliedFor = null;
|
||||
var defaultEntityType = null;
|
||||
|
||||
switch (defaultTemplateType) {
|
||||
case 'archive':
|
||||
defaultAppliedFor = RULE_TAXONOMY;
|
||||
defaultEntityType = 'category';
|
||||
break;
|
||||
case 'single_product':
|
||||
defaultAppliedFor = RULE_POSTS;
|
||||
defaultEntityType = 'product';
|
||||
break;
|
||||
case 'product_archive':
|
||||
defaultAppliedFor = WOO_PAGES;
|
||||
defaultEntityType = 'shop_page';
|
||||
break;
|
||||
default:
|
||||
defaultAppliedFor = RULE_POSTS;
|
||||
defaultEntityType = 'post';
|
||||
break;
|
||||
}
|
||||
|
||||
|
||||
var defaultRule = {
|
||||
type: RULE_TYPE_INCLUDE,
|
||||
appliedFor: defaultAppliedFor,
|
||||
entityType: defaultEntityType,
|
||||
entityValues: []
|
||||
};
|
||||
|
||||
var state = {
|
||||
locked: false,
|
||||
templateType: defaultTemplateType,
|
||||
rule: defaultRule,
|
||||
rules: {
|
||||
single: [],
|
||||
archive: [],
|
||||
single_product: [],
|
||||
product_archive: [],
|
||||
},
|
||||
errors: "",
|
||||
groups: [],
|
||||
};
|
||||
|
||||
state.rules[state.templateType] = Brizy_Admin_Rules.rules;
|
||||
|
||||
var apiCache = {
|
||||
groupList: null,
|
||||
postGroupListPromise: [],
|
||||
archiveGroupListPromise: [],
|
||||
templateGroupListPromise: [],
|
||||
postList: [],
|
||||
termList: []
|
||||
};
|
||||
|
||||
var api = {
|
||||
getGroupList: function (templateType) {
|
||||
|
||||
if (!apiCache.groupList) {
|
||||
apiCache.groupList = [];
|
||||
}
|
||||
|
||||
if (apiCache.groupList && apiCache.groupList[templateType])
|
||||
return apiCache.groupList[templateType];
|
||||
|
||||
return apiCache.groupList[templateType] = jQuery.getJSON(Brizy_Admin_Rules.url, {
|
||||
action: Brizy_Admin_Rules.prefix + "_rule_group_list",
|
||||
hash: Brizy_Admin_Rules.hash,
|
||||
version: Brizy_Admin_Data.editorVersion,
|
||||
context: 'template-rules',
|
||||
templateType: templateType
|
||||
})
|
||||
},
|
||||
|
||||
getPostsGroupList: function (postType, templateType) {
|
||||
|
||||
if (apiCache.postGroupListPromise[postType + templateType])
|
||||
return apiCache.postGroupListPromise[postType + templateType];
|
||||
|
||||
return apiCache.postGroupListPromise[postType + templateType] = jQuery.getJSON(Brizy_Admin_Rules.url, {
|
||||
action: Brizy_Admin_Rules.prefix + "_rule_posts_group_list",
|
||||
postType: postType,
|
||||
hash: Brizy_Admin_Rules.hash,
|
||||
version: Brizy_Admin_Data.editorVersion,
|
||||
context: 'template-rules',
|
||||
templateType: templateType
|
||||
})
|
||||
},
|
||||
|
||||
getArchiveGroupList: function (taxonomy, templateType) {
|
||||
|
||||
if (apiCache.archiveGroupListPromise[taxonomy + templateType])
|
||||
return apiCache.archiveGroupListPromise[taxonomy + templateType];
|
||||
|
||||
return apiCache.archiveGroupListPromise[taxonomy + templateType] = jQuery.getJSON(Brizy_Admin_Rules.url, {
|
||||
action: Brizy_Admin_Rules.prefix + "_rule_archive_group_list",
|
||||
taxonomy: taxonomy,
|
||||
hash: Brizy_Admin_Rules.hash,
|
||||
version: Brizy_Admin_Data.editorVersion,
|
||||
context: 'template-rules',
|
||||
templateType: templateType
|
||||
})
|
||||
},
|
||||
|
||||
getTemplateGroupList: function (templateType) {
|
||||
if (apiCache.templateGroupListPromise[templateType + '-author'])
|
||||
return apiCache.templateGroupListPromise[templateType + '-author'];
|
||||
|
||||
return apiCache.templateGroupListPromise[templateType + '-author'] = jQuery.getJSON(Brizy_Admin_Rules.url, {
|
||||
action: Brizy_Admin_Rules.prefix + "_rule_template_group_list",
|
||||
hash: Brizy_Admin_Rules.hash,
|
||||
version: Brizy_Admin_Data.editorVersion,
|
||||
context: 'template-rules',
|
||||
templateType: templateType
|
||||
})
|
||||
},
|
||||
|
||||
getTerms: function (taxonomy) {
|
||||
if (apiCache.termList[taxonomy])
|
||||
return apiCache.termList[taxonomy];
|
||||
|
||||
return jQuery.getJSON(Brizy_Admin_Rules.url, {
|
||||
action: Brizy_Admin_Rules.prefix + "_get_terms",
|
||||
hash: Brizy_Admin_Rules.hash,
|
||||
version: Brizy_Admin_Data.editorVersion,
|
||||
taxonomy: taxonomy
|
||||
}).done(function (data) {
|
||||
apiCache.termList[taxonomy] = jQuery.Deferred().resolve(data);
|
||||
});
|
||||
},
|
||||
|
||||
validateRule: function (rule) {
|
||||
|
||||
var url = new URL(Brizy_Admin_Rules.url);
|
||||
url.searchParams.append('action', Brizy_Admin_Rules.prefix + '_validate_rule');
|
||||
url.searchParams.append('hash', Brizy_Admin_Rules.hash);
|
||||
url.searchParams.append('post', Brizy_Admin_Rules.id);
|
||||
url.searchParams.append('version', Brizy_Admin_Data.editorVersion);
|
||||
url.searchParams.append('dataVersion', 0);
|
||||
url.searchParams.append('ignoreDataVersion', 1);
|
||||
|
||||
return jQuery.ajax({
|
||||
type: "POST",
|
||||
url: url.toString(),
|
||||
data: JSON.stringify(rule),
|
||||
contentType: "application/json; charset=utf-8"
|
||||
});
|
||||
},
|
||||
};
|
||||
|
||||
var actions = {
|
||||
getState: function (value) {
|
||||
return function (state) {
|
||||
return state;
|
||||
};
|
||||
},
|
||||
|
||||
updateGroups: function (value) {
|
||||
return function (state) {
|
||||
return {
|
||||
groups: value,
|
||||
};
|
||||
};
|
||||
},
|
||||
setLocked: function (value) {
|
||||
return function (state) {
|
||||
return {
|
||||
locked: value,
|
||||
};
|
||||
};
|
||||
},
|
||||
rule: {
|
||||
update: function (rule) {
|
||||
return function (state) {
|
||||
return rule;
|
||||
};
|
||||
},
|
||||
|
||||
setType: function (value) {
|
||||
return function (state) {
|
||||
return {type: value};
|
||||
};
|
||||
},
|
||||
setAppliedFor: function (value) {
|
||||
return function (state) {
|
||||
return {appliedFor: value};
|
||||
};
|
||||
},
|
||||
setEntityType: function (value) {
|
||||
return function (state) {
|
||||
return {entityType: value};
|
||||
};
|
||||
},
|
||||
setEntityValues: function (value) {
|
||||
return function (state) {
|
||||
return {entityValues: value};
|
||||
};
|
||||
}
|
||||
},
|
||||
|
||||
resetRule: function () {
|
||||
return function (state) {
|
||||
switch (state.templateType) {
|
||||
case 'archive':
|
||||
defaultAppliedFor = RULE_TAXONOMY;
|
||||
defaultEntityType = 'category';
|
||||
break;
|
||||
|
||||
default:
|
||||
defaultAppliedFor = RULE_POSTS;
|
||||
defaultEntityType = 'post';
|
||||
break;
|
||||
}
|
||||
|
||||
var defaultRule = {
|
||||
type: RULE_TYPE_INCLUDE,
|
||||
appliedFor: defaultAppliedFor,
|
||||
entityType: defaultEntityType,
|
||||
entityValues: []
|
||||
};
|
||||
|
||||
return {errors: "", rule: defaultRule};
|
||||
};
|
||||
},
|
||||
addFormErrors: function (errors) {
|
||||
return function (state) {
|
||||
return {errors: errors};
|
||||
};
|
||||
},
|
||||
|
||||
addRule: function (rule) {
|
||||
return function (state) {
|
||||
|
||||
switch (state.templateType) {
|
||||
case 'archive':
|
||||
defaultAppliedFor = RULE_TAXONOMY;
|
||||
defaultEntityType = 'category';
|
||||
break;
|
||||
|
||||
default:
|
||||
defaultAppliedFor = RULE_POSTS;
|
||||
defaultEntityType = 'post';
|
||||
break;
|
||||
}
|
||||
|
||||
var defaultRule = {
|
||||
type: RULE_TYPE_INCLUDE,
|
||||
appliedFor: defaultAppliedFor,
|
||||
entityType: defaultEntityType,
|
||||
entityValues: []
|
||||
};
|
||||
|
||||
return {
|
||||
rules: {[state.templateType]: [...state.rules[state.templateType] || [], rule]},
|
||||
rule: defaultRule,
|
||||
errors: ""
|
||||
};
|
||||
};
|
||||
},
|
||||
removeRule: function (rule) {
|
||||
return function (state) {
|
||||
var rules = state.rules[state.templateType];
|
||||
rules.splice(rules.indexOf(rule), 1);
|
||||
return {
|
||||
rules: {
|
||||
[state.templateType]: rules
|
||||
}
|
||||
};
|
||||
};
|
||||
},
|
||||
setTemplateType: function (type) {
|
||||
return function (state) {
|
||||
return {
|
||||
templateType: type,
|
||||
};
|
||||
};
|
||||
}
|
||||
};
|
||||
|
||||
function arr_diff(a1, a2) {
|
||||
|
||||
var a = [], diff = [];
|
||||
|
||||
for (var i = 0; i < a1.length; i++) {
|
||||
a[a1[i]] = true;
|
||||
}
|
||||
|
||||
for (var i = 0; i < a2.length; i++) {
|
||||
if (a[a2[i]]) {
|
||||
delete a[a2[i]];
|
||||
} else {
|
||||
a[a2[i]] = true;
|
||||
}
|
||||
}
|
||||
|
||||
for (var k in a) {
|
||||
diff.push(k);
|
||||
}
|
||||
|
||||
return diff;
|
||||
}
|
||||
|
||||
|
||||
var RuleTypeField = function (params) {
|
||||
return function (state, action) {
|
||||
return h(
|
||||
"span",
|
||||
{
|
||||
class: "brizy-rule-select",
|
||||
},
|
||||
|
||||
h(
|
||||
"select",
|
||||
{
|
||||
name: params.name,
|
||||
style: {width: "100px"},
|
||||
// oncreate: function (element) {
|
||||
// var el = jQuery(element);
|
||||
// el.on("change", function(e){ action.rule.setType(e.target.value); });
|
||||
// el.select2();
|
||||
// },
|
||||
// onremove: function (element, done) {
|
||||
// jQuery(element).select2("destroy");
|
||||
// done();
|
||||
// },
|
||||
onchange: function (e) {
|
||||
action.rule.setType(e.target.value);
|
||||
}
|
||||
},
|
||||
[
|
||||
h(
|
||||
"option",
|
||||
{
|
||||
value: RULE_TYPE_INCLUDE,
|
||||
selected: parseInt(params.value) === RULE_TYPE_INCLUDE
|
||||
},
|
||||
"Include"
|
||||
),
|
||||
h(
|
||||
"option",
|
||||
{
|
||||
value: RULE_TYPE_EXCLUDE,
|
||||
selected: parseInt(params.value) === RULE_TYPE_EXCLUDE
|
||||
},
|
||||
"Exclude"
|
||||
)
|
||||
]
|
||||
)
|
||||
);
|
||||
};
|
||||
};
|
||||
|
||||
var BrzSelect2 = function (params) {
|
||||
|
||||
var oncreate = function (element) {
|
||||
|
||||
var el = jQuery(element);
|
||||
el.on("change", params.onChange);
|
||||
|
||||
if (typeof params.optionRequest === 'function') {
|
||||
const optionRequest = params.optionRequest();
|
||||
|
||||
if (typeof params.optionRequest === 'function') {
|
||||
optionRequest.done(function (response) {
|
||||
var options = params.convertResponseToOptions(response);
|
||||
options.forEach(function (option) {
|
||||
el.append(option);
|
||||
});
|
||||
el.select2();
|
||||
});
|
||||
} else {
|
||||
var options = params.convertResponseToOptions(optionRequest);
|
||||
options.forEach(function (option) {
|
||||
el.append(option);
|
||||
});
|
||||
el.select2();
|
||||
}
|
||||
}
|
||||
};
|
||||
|
||||
var onremove = function (element, done) {
|
||||
if (jQuery(element).data('select2')) {
|
||||
jQuery(element).select2("destroy");
|
||||
}
|
||||
done();
|
||||
};
|
||||
|
||||
return h(
|
||||
"select",
|
||||
{
|
||||
key: params.id + '|' + params.value,
|
||||
akey: params.id + '|' + params.value,
|
||||
style: params.style,
|
||||
oncreate: oncreate,
|
||||
onremove: onremove,
|
||||
name: params.name,
|
||||
},
|
||||
[]
|
||||
);
|
||||
};
|
||||
|
||||
var RulePostsGroupSelectField = function (params) {
|
||||
return function (state, actions) {
|
||||
var appliedFor = params.rule.appliedFor;
|
||||
var entityType = params.rule.entityType;
|
||||
var value = String(params.rule.entityValues[0] ? params.rule.entityValues[0] : '');
|
||||
|
||||
var convertResponseToOptions = function (response) {
|
||||
var groups = [];
|
||||
groups.push(new Option("All", '', true, value === ''));
|
||||
response.data.forEach(function (group) {
|
||||
if (group.title === "") {
|
||||
group.items.forEach(function (option) {
|
||||
var optionValue = String(option.value);
|
||||
var selected = params.rule.entityValues.includes(optionValue);
|
||||
groups.push(new Option(option.title, optionValue, false, selected));
|
||||
});
|
||||
} else {
|
||||
var groupElement = document.createElement("OPTGROUP");
|
||||
groupElement.label = group.title;
|
||||
|
||||
if (group.items.length > 0) {
|
||||
group.items.forEach(function (option) {
|
||||
var optionValue = String(option.value);
|
||||
var selected = params.rule.entityValues.includes(optionValue);
|
||||
groupElement.appendChild(new Option(option.title, optionValue, false, selected))
|
||||
});
|
||||
groups.push(groupElement);
|
||||
}
|
||||
}
|
||||
});
|
||||
|
||||
return groups;
|
||||
};
|
||||
|
||||
|
||||
return h(
|
||||
BrzSelect2,
|
||||
{
|
||||
id: "post-groups-" + entityType + '-' + params.type,
|
||||
style: params.style ? params.style : {width: "200px"},
|
||||
name: params.name,
|
||||
optionRequest: function () {
|
||||
actions.setLocked(true);
|
||||
return api.getPostsGroupList(entityType, params.type).done(function (data) {
|
||||
actions.setLocked(false);
|
||||
return data;
|
||||
});
|
||||
},
|
||||
convertResponseToOptions: convertResponseToOptions,
|
||||
onChange: params.onChange,
|
||||
},
|
||||
[]
|
||||
);
|
||||
}
|
||||
};
|
||||
|
||||
var RuleArchiveGroupSelectField = function (params) {
|
||||
return function (state, actions) {
|
||||
var appliedFor = params.rule.appliedFor;
|
||||
var taxonomy = params.rule.entityType;
|
||||
var value = String(params.rule.entityValues[0] ? params.rule.entityValues[0] : '');
|
||||
|
||||
var convertResponseToOptions = function (response) {
|
||||
var groups = [];
|
||||
groups.push(new Option("All", '', false, value === ''));
|
||||
response.data.forEach(function (group) {
|
||||
|
||||
if (group.title === "") {
|
||||
group.items.forEach(function (option) {
|
||||
var optionValue = String(option.value);
|
||||
groups.push(new Option(option.title, optionValue, false, params.rule.entityValues.includes(optionValue)));
|
||||
});
|
||||
} else {
|
||||
var groupElement = document.createElement("OPTGROUP");
|
||||
groupElement.label = group.title;
|
||||
|
||||
if (group.items.length > 0) {
|
||||
group.items.forEach(function (option) {
|
||||
var optionValue = String(option.value);
|
||||
groupElement.appendChild(new Option(option.title, optionValue, false, params.rule.entityValues.includes(optionValue)))
|
||||
});
|
||||
groups.push(groupElement);
|
||||
}
|
||||
}
|
||||
});
|
||||
|
||||
return groups;
|
||||
};
|
||||
|
||||
return h(
|
||||
BrzSelect2,
|
||||
{
|
||||
id: "archive-groups-" + params.taxonomy,
|
||||
style: params.style ? params.style : {width: "200px"},
|
||||
name: params.name,
|
||||
optionRequest: function () {
|
||||
actions.setLocked(true);
|
||||
return api.getArchiveGroupList(taxonomy, params.type).done(function (data) {
|
||||
actions.setLocked(false);
|
||||
return data;
|
||||
});
|
||||
},
|
||||
convertResponseToOptions: convertResponseToOptions,
|
||||
onChange: params.onChange,
|
||||
},
|
||||
[]
|
||||
);
|
||||
}
|
||||
};
|
||||
|
||||
var RuleAuthorGroupSelectField = function (params) {
|
||||
return function (state, actions) {
|
||||
var appliedFor = params.rule.appliedFor;
|
||||
var taxonomy = params.rule.entityType;
|
||||
var value = String(params.rule.entityValues[0] ? params.rule.entityValues[0] : '');
|
||||
|
||||
var convertResponseToOptions = function (response) {
|
||||
var groups = [];
|
||||
groups.push(new Option("All", '', false, value === ''));
|
||||
response.data.forEach(function (group) {
|
||||
|
||||
if (group.title === "") {
|
||||
group.items.forEach(function (option) {
|
||||
var optionValue = String(option.value);
|
||||
groups.push(new Option(option.title, optionValue, false, params.rule.entityValues.includes(optionValue)));
|
||||
});
|
||||
} else {
|
||||
var groupElement = document.createElement("OPTGROUP");
|
||||
groupElement.label = group.title;
|
||||
|
||||
if (group.items.length > 0) {
|
||||
group.items.forEach(function (option) {
|
||||
var optionValue = String(option.value);
|
||||
groupElement.appendChild(new Option(option.title, optionValue, false, params.rule.entityValues.includes(optionValue)))
|
||||
});
|
||||
groups.push(groupElement);
|
||||
}
|
||||
}
|
||||
});
|
||||
|
||||
return groups;
|
||||
};
|
||||
|
||||
return h(
|
||||
BrzSelect2,
|
||||
{
|
||||
id: "archive-groups-author",
|
||||
style: params.style ? params.style : {width: "200px"},
|
||||
name: params.name,
|
||||
optionRequest: function () {
|
||||
actions.setLocked(true);
|
||||
return api.getTemplateGroupList(params.type).done(function (data) {
|
||||
actions.setLocked(false);
|
||||
return data;
|
||||
});
|
||||
},
|
||||
convertResponseToOptions: convertResponseToOptions,
|
||||
onChange: params.onChange,
|
||||
},
|
||||
[]
|
||||
);
|
||||
}
|
||||
};
|
||||
|
||||
var RuleApplyGroupField = function (params) {
|
||||
return function (state, actions) {
|
||||
|
||||
var appliedFor = params.rule.appliedFor;
|
||||
var entityType = params.rule.entityType;
|
||||
var value = appliedFor + "|" + entityType;
|
||||
var groups = [];
|
||||
|
||||
params.groups.forEach(function (group) {
|
||||
var options = [];
|
||||
group.items.forEach(function (option) {
|
||||
var optionValue = option.groupValue + "|" + option.value;
|
||||
var attributes = {
|
||||
value: optionValue,
|
||||
selected: optionValue === value
|
||||
};
|
||||
options.push(h("option", attributes, option.title));
|
||||
});
|
||||
const attributes = {label: group.title};
|
||||
|
||||
if (group.value + "|" === "|") {
|
||||
groups.push(h("option", {value: "|"}, group.title));
|
||||
} else {
|
||||
groups.push(h("optgroup", attributes, options));
|
||||
}
|
||||
});
|
||||
|
||||
const attributes = {
|
||||
name: params.name,
|
||||
style: {width: "200px"},
|
||||
class: "brizy-rule-select--options[] ",
|
||||
onchange: function (e) {
|
||||
var values = e.target.value.split("|");
|
||||
actions.rule.update({
|
||||
appliedFor: parseInt(values[0]),
|
||||
entityType: values[1],
|
||||
entityValues: []
|
||||
});
|
||||
}
|
||||
};
|
||||
|
||||
var elements = [
|
||||
h("span", {class: "brizy-rule-select brizy-rule-select2"},
|
||||
h("select", attributes, groups)
|
||||
)
|
||||
];
|
||||
|
||||
switch (parseInt(appliedFor)) {
|
||||
case RULE_POSTS:
|
||||
elements.push(
|
||||
h("span", {class: "brizy-rule-select brizy-rule-select2"}, [
|
||||
h(RulePostsGroupSelectField, {
|
||||
id: params.type + appliedFor + value,
|
||||
key: params.type + appliedFor + value,
|
||||
rule: params.rule,
|
||||
type: params.type,
|
||||
name: params.type ? 'brizy-' + params.type + '-rule-entity-values[]' : '',
|
||||
onChange: function (e) {
|
||||
actions.rule.update({
|
||||
entityValues: e.target.value ? [e.target.value] : [],
|
||||
});
|
||||
}
|
||||
})
|
||||
]));
|
||||
break;
|
||||
case RULE_TAXONOMY:
|
||||
elements.push(
|
||||
h("span", {class: "brizy-rule-select brizy-rule-select2"}, [
|
||||
h(RuleArchiveGroupSelectField, {
|
||||
id: params.type + appliedFor + value,
|
||||
key: params.type + appliedFor + value,
|
||||
rule: params.rule,
|
||||
type: params.type,
|
||||
taxonomy: entityType,
|
||||
name: params.type ? 'brizy-' + params.type + '-rule-entity-values[]' : '',
|
||||
onChange: function (e) {
|
||||
actions.rule.update({
|
||||
entityValues: e.target.value ? [e.target.value] : [],
|
||||
});
|
||||
}
|
||||
})
|
||||
]));
|
||||
break;
|
||||
|
||||
case RULE_TEMPLATE:
|
||||
if (entityType === 'author') {
|
||||
elements.push(
|
||||
h("span", {class: "brizy-rule-select brizy-rule-select2"}, [
|
||||
h(RuleAuthorGroupSelectField, {
|
||||
id: params.type + appliedFor + value,
|
||||
key: params.type + appliedFor + value,
|
||||
rule: params.rule,
|
||||
type: params.type,
|
||||
name: params.type ? 'brizy-' + params.type + '-rule-entity-values[]' : '',
|
||||
onChange: function (e) {
|
||||
actions.rule.update({
|
||||
entityValues: e.target.value ? [e.target.value] : [],
|
||||
});
|
||||
}
|
||||
})
|
||||
]));
|
||||
}
|
||||
break;
|
||||
|
||||
|
||||
}
|
||||
return h("span", {}, elements);
|
||||
};
|
||||
};
|
||||
|
||||
var RuleForm = function (params) {
|
||||
var elements = [
|
||||
h("h4", {}, "Add New Condition"),
|
||||
h(RuleTypeField, {value: String(params.rule.type)}),
|
||||
h(RuleApplyGroupField, {rule: params.rule, groups: params.groups, type: params.type}),
|
||||
h("input", {
|
||||
type: "button",
|
||||
class: "button",
|
||||
onclick: params.onSubmit,
|
||||
value: "Add"
|
||||
})
|
||||
];
|
||||
|
||||
if (params.errors) {
|
||||
elements.push(h("p", {class: "error"}, params.errors));
|
||||
}
|
||||
|
||||
return h("div", {class: "brizy-rule-new-condition"}, elements);
|
||||
};
|
||||
|
||||
var RuleListItem = function (params) {
|
||||
var rule = params.rule;
|
||||
var key = 'list-' + rule.type + rule.appliedType + rule.appliedFor + rule.entityValues.join('') + params.index;
|
||||
return h("div", {class: "rule", key: key}, [
|
||||
|
||||
h("span", {class: 'rule-fields'}, [
|
||||
h(RuleTypeField, {value: String(params.rule.type), name: 'brizy-' + params.type + '-rule-type[]'}),
|
||||
h(RuleApplyGroupField, {
|
||||
rule: params.rule,
|
||||
groups: params.groups,
|
||||
type: params.type,
|
||||
name: 'brizy-' + params.type + '-rule-group[]'
|
||||
}),
|
||||
h('div', {class: 'overlay'}, [])
|
||||
]),
|
||||
h("input", {
|
||||
class: "brizy-delete-rule ",
|
||||
type: "button",
|
||||
value: "Delete",
|
||||
onclick: function (e) {
|
||||
if (confirm('Are you sure you want to delete?'))
|
||||
params.onDelete(params.rule);
|
||||
}
|
||||
})
|
||||
]);
|
||||
};
|
||||
|
||||
var RuleList = function (params) {
|
||||
var elements = [];
|
||||
if (params.rules.length) {
|
||||
elements.push(h("h4", {}, "Where do You Want to Display it"));
|
||||
}
|
||||
|
||||
params.rules.forEach(function (rule, index) {
|
||||
elements.push(
|
||||
h(RuleListItem, {
|
||||
index: index,
|
||||
rule: rule,
|
||||
groups: params.groups,
|
||||
onDelete: params.onDelete,
|
||||
type: params.type
|
||||
})
|
||||
);
|
||||
});
|
||||
|
||||
return h("div", {}, elements);
|
||||
};
|
||||
|
||||
var TemplateTypeSelect = function (params) {
|
||||
return h(
|
||||
"fieldset", {class: 'brizy-template-type'}, [
|
||||
h('h4', {}, 'Template Type'),
|
||||
h('label', {}, [
|
||||
h('input', {
|
||||
type: 'radio',
|
||||
name: 'brizy-template-type',
|
||||
onchange: params.onChange,
|
||||
value: 'single',
|
||||
checked: 'single' === params.value
|
||||
}),
|
||||
h('span', {class: "date-time-text format-i18n"}, Brizy_Admin_Rules.labels.single),
|
||||
]),
|
||||
h('label', {}, [
|
||||
h('input', {
|
||||
type: 'radio',
|
||||
name: 'brizy-template-type',
|
||||
onchange: params.onChange,
|
||||
value: 'archive',
|
||||
checked: 'archive' === params.value
|
||||
}),
|
||||
h('span', {class: "date-time-text format-i18n"}, Brizy_Admin_Rules.labels.archive),
|
||||
]),
|
||||
...(Brizy_Admin_Rules.labels.single_product ?
|
||||
[h('label', {}, [
|
||||
h('input', {
|
||||
type: 'radio',
|
||||
name: 'brizy-template-type',
|
||||
onchange: params.onChange,
|
||||
value: 'single_product',
|
||||
checked: 'single_product' === params.value
|
||||
}),
|
||||
h('span', {class: "date-time-text format-i18n"}, Brizy_Admin_Rules.labels.single_product),
|
||||
]), h('label', {}, [
|
||||
h('input', {
|
||||
type: 'radio',
|
||||
name: 'brizy-template-type',
|
||||
onchange: params.onChange,
|
||||
value: 'product_archive',
|
||||
checked: 'product_archive' === params.value
|
||||
}),
|
||||
h('span', {class: "date-time-text format-i18n"}, Brizy_Admin_Rules.labels.product_archive),
|
||||
])] : []),
|
||||
]
|
||||
);
|
||||
};
|
||||
|
||||
var ruleView = function (state, actions) {
|
||||
|
||||
return h(
|
||||
"div",
|
||||
{
|
||||
class: "rules-container",
|
||||
oncreate: function () {
|
||||
if (state.templateType != '')
|
||||
actions.setLocked(true);
|
||||
api.getGroupList(state.templateType).done(function (response) {
|
||||
actions.updateGroups(response.data)
|
||||
actions.setLocked(false);
|
||||
});
|
||||
},
|
||||
},
|
||||
[
|
||||
h(
|
||||
TemplateTypeSelect, {
|
||||
value: state.templateType,
|
||||
onChange: function (e) {
|
||||
const type = e.target.value && e.target.value != "null"
|
||||
? e.target.value
|
||||
: null;
|
||||
|
||||
actions.setLocked(true);
|
||||
actions.setTemplateType(type);
|
||||
api.getGroupList(type).done(function (response) {
|
||||
actions.updateGroups(response.data);
|
||||
actions.rule.update({
|
||||
appliedFor: String(response.data[0].value),
|
||||
entityType: String(response.data[0].items[0].value),
|
||||
});
|
||||
actions.setLocked(false);
|
||||
});
|
||||
}
|
||||
}, []
|
||||
),
|
||||
h(RuleList, {
|
||||
type: state.templateType,
|
||||
rules: state.rules[state.templateType] || [],
|
||||
groups: state.groups,
|
||||
onDelete: function (rule) {
|
||||
actions.removeRule(rule);
|
||||
}
|
||||
}),
|
||||
state.templateType ? [
|
||||
h(RuleForm, {
|
||||
type: state.templateType,
|
||||
rule: state.rule,
|
||||
groups: state.groups,
|
||||
errors: state.errors,
|
||||
onSubmit: function () {
|
||||
var rules = state.rules[state.templateType] || [];
|
||||
|
||||
try {
|
||||
rules.forEach(rule => {
|
||||
if (rule.type !== state.rule.type) return;
|
||||
if (rule.appliedFor !== state.rule.appliedFor) return;
|
||||
if (rule.entityType !== state.rule.entityType) return;
|
||||
if (arr_diff(rule.entityValues, state.rule.entityValues).length > 0) return;
|
||||
throw 'This rule already exist';
|
||||
});
|
||||
} catch (error) {
|
||||
actions.addFormErrors('This rule already exist');
|
||||
return;
|
||||
}
|
||||
api.validateRule(state.rule)
|
||||
.done(function () {
|
||||
actions.addRule(state.rule);
|
||||
actions.resetRule();
|
||||
})
|
||||
.fail(function (response) {
|
||||
if (response.responseJSON && response.responseJSON.data) {
|
||||
if (response.responseJSON.data.message)
|
||||
actions.addFormErrors(response.responseJSON.data.message);
|
||||
else
|
||||
actions.addFormErrors("Failed to add the rule");
|
||||
}
|
||||
});
|
||||
}
|
||||
})] :
|
||||
[],
|
||||
state.locked ? [h('div', {class: 'lock-screen'}, "Loading..")] : [],
|
||||
]
|
||||
);
|
||||
};
|
||||
|
||||
jQuery(document).ready(function ($) {
|
||||
hyperapp.app(state, actions, ruleView, document.getElementById("rules"));
|
||||
});
|
||||
|
||||
Reference in New Issue
Block a user