add error handling in listmap, improve setting the error class in inputs and arrayinputs
This commit is contained in:
parent
a5a833f3c1
commit
bbef38f0a9
3 changed files with 112 additions and 72 deletions
|
@ -1,3 +1,7 @@
|
||||||
|
/*@
|
||||||
|
Ox.ArrayInput <f> Array input
|
||||||
|
@*/
|
||||||
|
|
||||||
Ox.ArrayInput = function(options, self) {
|
Ox.ArrayInput = function(options, self) {
|
||||||
|
|
||||||
self = self || {};
|
self = self || {};
|
||||||
|
@ -141,7 +145,6 @@ Ox.ArrayInput = function(options, self) {
|
||||||
|
|
||||||
self.setOption = function(key, value) {
|
self.setOption = function(key, value) {
|
||||||
if (key == 'value') {
|
if (key == 'value') {
|
||||||
Ox.print('--value--', value, self.$input)
|
|
||||||
if (self.options.value.length == 0) {
|
if (self.options.value.length == 0) {
|
||||||
self.options.value = [''];
|
self.options.value = [''];
|
||||||
}
|
}
|
||||||
|
@ -156,6 +159,12 @@ Ox.ArrayInput = function(options, self) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
that.setErrors = function(values) {
|
||||||
|
self.$input.forEach(function($input) {
|
||||||
|
values.indexOf($input.value()) > -1 && $input.addClass('OxError');
|
||||||
|
});
|
||||||
|
};
|
||||||
|
|
||||||
// fixme: can't we generally use options.value for this?
|
// fixme: can't we generally use options.value for this?
|
||||||
that.value = function() {
|
that.value = function() {
|
||||||
if (arguments.length == 0) {
|
if (arguments.length == 0) {
|
||||||
|
|
|
@ -810,6 +810,7 @@ Ox.Input = function(options, self) {
|
||||||
self.options.value = self.options.value.toFixed(self.options.decimals);
|
self.options.value = self.options.value.toFixed(self.options.decimals);
|
||||||
}
|
}
|
||||||
self.$input.val(self.options.value);
|
self.$input.val(self.options.value);
|
||||||
|
that.is('.OxError') && that.removeClass('OxError');
|
||||||
setPlaceholder();
|
setPlaceholder();
|
||||||
} else if (key == 'width') {
|
} else if (key == 'width') {
|
||||||
that.css({width: self.options.width + 'px'});
|
that.css({width: self.options.width + 'px'});
|
||||||
|
|
|
@ -356,7 +356,15 @@ Ox.ListMap = function(options, self) {
|
||||||
width: 208
|
width: 208
|
||||||
})
|
})
|
||||||
.css({float: 'left', margin: '4px 0 4px 0'})
|
.css({float: 'left', margin: '4px 0 4px 0'})
|
||||||
.appendTo(self.$placeTitle);
|
.appendTo(self.$placeTitle)
|
||||||
|
.bindEvent({
|
||||||
|
singleclick: function() {
|
||||||
|
self.$map.panToPlace();
|
||||||
|
},
|
||||||
|
doubleclick: function() {
|
||||||
|
self.$map.zoomToPlace();
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
self.$deselectPlaceButton = Ox.Button({
|
self.$deselectPlaceButton = Ox.Button({
|
||||||
title: 'close',
|
title: 'close',
|
||||||
|
@ -371,73 +379,80 @@ Ox.ListMap = function(options, self) {
|
||||||
})
|
})
|
||||||
.appendTo(self.$placeTitle);
|
.appendTo(self.$placeTitle);
|
||||||
|
|
||||||
// fixme: form should have a change event
|
self.$nameInput = Ox.Input({
|
||||||
self.$placeFormItems = Ox.merge([
|
id: 'name',
|
||||||
Ox.Input({
|
label: 'Name',
|
||||||
id: 'name',
|
labelWidth: 64,
|
||||||
label: 'Name',
|
width: 240
|
||||||
labelWidth: 64,
|
}).bindEvent({
|
||||||
width: 240
|
change: function(data) {
|
||||||
}).bindEvent({
|
var isResult = self.selectedPlace[0] == '_';
|
||||||
change: function(data) {
|
!isResult && self.$list.value(self.selectedPlace, 'name', data.value);
|
||||||
var isResult = self.selectedPlace[0] == '_';
|
if (!self.isAsync) {
|
||||||
!isResult && self.$list.value(self.selectedPlace, 'name', data.value);
|
Ox.getObjectById(
|
||||||
if (!self.isAsync) {
|
self.options.places, self.selectedPlace
|
||||||
Ox.getObjectById(
|
).name = data.value;
|
||||||
self.options.places, self.selectedPlace
|
} else {
|
||||||
).name = data.value;
|
!isResult && editPlace(['name']);
|
||||||
} else {
|
|
||||||
!isResult && editPlace(['name']);
|
|
||||||
}
|
|
||||||
self.$map.value(self.selectedPlace, 'name', data.value);
|
|
||||||
}
|
}
|
||||||
}),
|
self.$map.value(self.selectedPlace, 'name', data.value);
|
||||||
Ox.ArrayInput({
|
}
|
||||||
id: 'alternativeNames',
|
});
|
||||||
label: 'Alternative Names',
|
|
||||||
max: 10,
|
|
||||||
//sort: true,
|
|
||||||
values: [],
|
|
||||||
width: 240
|
|
||||||
}).bindEvent({
|
|
||||||
change: function(data) {
|
|
||||||
var isResult = self.selectedPlace[0] == '_';
|
|
||||||
if (!self.isAsync) {
|
|
||||||
|
|
||||||
} else {
|
self.$alternativeNamesInput = Ox.ArrayInput({
|
||||||
!isResult && editPlace(['alternativeNames'])
|
id: 'alternativeNames',
|
||||||
}
|
label: 'Alternative Names',
|
||||||
self.$map.value(self.selectedPlace, 'alternativeNames', data.value);
|
max: 10,
|
||||||
|
//sort: true,
|
||||||
|
values: [],
|
||||||
|
width: 240
|
||||||
|
}).bindEvent({
|
||||||
|
change: function(data) {
|
||||||
|
var isResult = self.selectedPlace[0] == '_';
|
||||||
|
if (!self.isAsync) {
|
||||||
|
|
||||||
|
} else {
|
||||||
|
!isResult && editPlace(['alternativeNames'])
|
||||||
}
|
}
|
||||||
}),
|
self.$map.value(self.selectedPlace, 'alternativeNames', data.value);
|
||||||
Ox.Input({
|
}
|
||||||
id: 'geoname',
|
});
|
||||||
label: 'Geoname',
|
|
||||||
labelWidth: 64,
|
self.$geonameInput = Ox.Input({
|
||||||
width: 240
|
id: 'geoname',
|
||||||
}).bindEvent({
|
label: 'Geoname',
|
||||||
change: function(data) {
|
labelWidth: 64,
|
||||||
var geoname = data.value,
|
width: 240
|
||||||
country = Ox.getCountryByGeoname(geoname),
|
}).bindEvent({
|
||||||
countryCode = country ? country.code : '',
|
change: function(data) {
|
||||||
isResult = self.selectedPlace[0] == '_';
|
var geoname = data.value,
|
||||||
self.$placeTitleFlag.attr({
|
country = Ox.getCountryByGeoname(geoname),
|
||||||
src: Ox.getImageByGeoname('icon', 16, geoname)
|
countryCode = country ? country.code : '',
|
||||||
});
|
isResult = self.selectedPlace[0] == '_';
|
||||||
self.$placeTitleName.options({title: geoname});
|
self.$placeTitleFlag.attr({
|
||||||
self.$placeForm.values({countryCode: countryCode});
|
src: Ox.getImageByGeoname('icon', 16, geoname)
|
||||||
if (!self.isAsync) {
|
});
|
||||||
if (!isResult) {
|
self.$placeTitleName.options({title: geoname});
|
||||||
self.$list.value(self.selectedPlace, 'geoname', geoname);
|
self.$placeForm.values({countryCode: countryCode});
|
||||||
self.$list.value(self.selectedPlace, 'countryCode', countryCode);
|
if (!self.isAsync) {
|
||||||
}
|
if (!isResult) {
|
||||||
} else {
|
self.$list.value(self.selectedPlace, 'geoname', geoname);
|
||||||
!isResult && editPlace(['countryCode', 'geoname']);
|
self.$list.value(self.selectedPlace, 'countryCode', countryCode);
|
||||||
}
|
}
|
||||||
self.$map.value(self.selectedPlace, 'countryCode', countryCode);
|
} else {
|
||||||
self.$map.value(self.selectedPlace, 'geoname', geoname);
|
!isResult && editPlace(['countryCode', 'geoname']);
|
||||||
}
|
}
|
||||||
}),
|
self.$map.value(self.selectedPlace, 'countryCode', countryCode);
|
||||||
|
self.$map.value(self.selectedPlace, 'geoname', geoname);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
// fixme: form should have a change event
|
||||||
|
// fixme: it has one now, but inputs fire on blur
|
||||||
|
self.$placeFormItems = Ox.merge([
|
||||||
|
self.$nameInput,
|
||||||
|
self.$alternativeNamesInput,
|
||||||
|
self.$geonameInput,
|
||||||
Ox.Input({
|
Ox.Input({
|
||||||
id: 'countryCode'
|
id: 'countryCode'
|
||||||
}).hide(),
|
}).hide(),
|
||||||
|
@ -661,18 +676,33 @@ Ox.ListMap = function(options, self) {
|
||||||
selected: [place.id]
|
selected: [place.id]
|
||||||
});
|
});
|
||||||
self.$map.addPlace(place);
|
self.$map.addPlace(place);
|
||||||
|
self.$placeButton.options({title: 'Remove Place'});
|
||||||
//setStatus();
|
//setStatus();
|
||||||
}
|
}
|
||||||
//that.triggerEvent('addplace', {place: place});
|
//that.triggerEvent('addplace', {place: place});
|
||||||
if (self.isAsync) {
|
if (self.isAsync) {
|
||||||
|
self.$placeButton.options({disabled: true, title: 'Adding Place'});
|
||||||
self.options.addPlace(place, function(result) {
|
self.options.addPlace(place, function(result) {
|
||||||
place.id = result.data.id;
|
if (result.status.code == 200) {
|
||||||
self.selectedPlace = place.id;
|
place.id = result.data.id;
|
||||||
self.$list.reloadList().options({selected: [place.id]});
|
self.selectedPlace = place.id;
|
||||||
self.$map.addPlace(place);
|
self.$list.reloadList().options({selected: [place.id]});
|
||||||
|
self.$map.addPlace(place);
|
||||||
|
self.$placeButton.options({disabled: false, title: 'Remove Place'});
|
||||||
|
} else {
|
||||||
|
if (result.data.names) {
|
||||||
|
if (result.data.names.indexOf(self.$nameInput.value()) > -1) {
|
||||||
|
self.$nameInput.addClass('OxError');
|
||||||
|
}
|
||||||
|
self.$alternativeNamesInput.setErrors(result.data.names);
|
||||||
|
}
|
||||||
|
if (result.data.geoname) {
|
||||||
|
self.$geonameInput.addClass('OxError');
|
||||||
|
}
|
||||||
|
self.$placeButton.options({disabled: false, title: 'Add Place'});
|
||||||
|
}
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
self.$placeButton.options({title: 'Remove Place'});
|
|
||||||
}
|
}
|
||||||
|
|
||||||
function editPlace(keys) {
|
function editPlace(keys) {
|
||||||
|
|
Loading…
Reference in a new issue