update manage places / manage events
This commit is contained in:
parent
a9089ee8f7
commit
e4b60c83c2
8 changed files with 676 additions and 482 deletions
|
@ -12,27 +12,72 @@ Ox.ListCalendar = function(options, self) {
|
||||||
var that = Ox.Element({}, self)
|
var that = Ox.Element({}, self)
|
||||||
.defaults({
|
.defaults({
|
||||||
addEvent: null,
|
addEvent: null,
|
||||||
editPlace: null,
|
collapsible: false,
|
||||||
|
editEvent: null,
|
||||||
events: [],
|
events: [],
|
||||||
|
hasMatches: false,
|
||||||
height: 256,
|
height: 256,
|
||||||
|
mode: 'add',
|
||||||
pageLength: 100,
|
pageLength: 100,
|
||||||
removePlace: null,
|
removeEvent: null,
|
||||||
selected: [],
|
selected: '',
|
||||||
showControls: false,
|
showControls: false,
|
||||||
sort: [{key: 'name', operator: '+'}],
|
sort: [{key: 'name', operator: '+'}],
|
||||||
width: 256
|
width: 256
|
||||||
})
|
})
|
||||||
.options(options || {})
|
.options(options || {})
|
||||||
.addClass('OxListCalendar')
|
|
||||||
.css({
|
.css({
|
||||||
width: self.options.width + 'px',
|
width: self.options.width + 'px',
|
||||||
height: self.options.height + 'px'
|
height: self.options.height + 'px'
|
||||||
});
|
});
|
||||||
|
|
||||||
|
Ox.print('LCO', self.options)
|
||||||
|
|
||||||
self.durationCache = {};
|
self.durationCache = {};
|
||||||
|
self.durationSize = {
|
||||||
|
86400: 10,
|
||||||
|
31622400: 12
|
||||||
|
};
|
||||||
|
|
||||||
self.columns = [
|
self.columns = [
|
||||||
{
|
{
|
||||||
|
format: function(value, data) {
|
||||||
|
var eventDuration = (Ox.parseDate(data.end) - Ox.parseDate(data.start)) / 1000,
|
||||||
|
iconSize = 8;
|
||||||
|
Ox.forEach(self.durationSize, function(size, duration) {
|
||||||
|
if (eventDuration >= duration) {
|
||||||
|
iconSize = size;
|
||||||
|
} else {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
});
|
||||||
|
return data.type
|
||||||
|
? $('<div>')
|
||||||
|
.addClass('OxEvent Ox' + Ox.toTitleCase(data.type))
|
||||||
|
.css({
|
||||||
|
width: iconSize + 'px',
|
||||||
|
height: iconSize + 'px',
|
||||||
|
margin: [0, 0, 0, -3].map(function(v) {
|
||||||
|
return v + (14 - iconSize) / 2 + 'px';
|
||||||
|
}).join(' '),
|
||||||
|
borderRadius: '2px'
|
||||||
|
})
|
||||||
|
: '';
|
||||||
|
},
|
||||||
|
id: 'type',
|
||||||
|
operator: '+',
|
||||||
|
title: 'Type',
|
||||||
|
titleImage: 'icon',
|
||||||
|
visible: true,
|
||||||
|
width: 16
|
||||||
|
},
|
||||||
|
{
|
||||||
|
format: function(value, data) {
|
||||||
|
Ox.print('format', value, data)
|
||||||
|
return data.type
|
||||||
|
? value
|
||||||
|
: $('<span>').addClass('OxWarning').html(value);
|
||||||
|
},
|
||||||
id: 'name',
|
id: 'name',
|
||||||
operator: '+',
|
operator: '+',
|
||||||
removable: false,
|
removable: false,
|
||||||
|
@ -51,16 +96,6 @@ Ox.ListCalendar = function(options, self) {
|
||||||
visible: true,
|
visible: true,
|
||||||
width: 144
|
width: 144
|
||||||
},
|
},
|
||||||
{
|
|
||||||
format: function(value) {
|
|
||||||
return Ox.toTitleCase(value);
|
|
||||||
},
|
|
||||||
id: 'type',
|
|
||||||
operator: '+',
|
|
||||||
title: 'Type',
|
|
||||||
visible: true,
|
|
||||||
width: 64
|
|
||||||
},
|
|
||||||
{
|
{
|
||||||
id: 'start',
|
id: 'start',
|
||||||
map: function(value) {
|
map: function(value) {
|
||||||
|
@ -128,16 +163,17 @@ Ox.ListCalendar = function(options, self) {
|
||||||
title: 'Date Modified',
|
title: 'Date Modified',
|
||||||
visible: false,
|
visible: false,
|
||||||
width: 128,
|
width: 128,
|
||||||
},
|
}
|
||||||
{
|
];
|
||||||
|
|
||||||
|
self.options.hasMatches && self.columns.push({
|
||||||
align: 'right',
|
align: 'right',
|
||||||
id: 'matches',
|
id: 'matches',
|
||||||
operator: '-',
|
operator: '-',
|
||||||
title: 'Matches',
|
title: 'Matches',
|
||||||
visible: false,
|
visible: true,
|
||||||
width: 64,
|
width: 64,
|
||||||
}
|
});
|
||||||
];
|
|
||||||
|
|
||||||
self.$listToolbar = Ox.Bar({
|
self.$listToolbar = Ox.Bar({
|
||||||
size: 24
|
size: 24
|
||||||
|
@ -176,11 +212,6 @@ Ox.ListCalendar = function(options, self) {
|
||||||
]
|
]
|
||||||
})
|
})
|
||||||
.css({float: 'right', margin: '4px'})
|
.css({float: 'right', margin: '4px'})
|
||||||
.bindEvent({
|
|
||||||
change: function(data) {
|
|
||||||
|
|
||||||
}
|
|
||||||
})
|
|
||||||
.appendTo(self.$listToolbar);
|
.appendTo(self.$listToolbar);
|
||||||
|
|
||||||
self.$list = Ox.TextList({
|
self.$list = Ox.TextList({
|
||||||
|
@ -191,8 +222,12 @@ Ox.ListCalendar = function(options, self) {
|
||||||
// self.$list.options({items: self.options.events}) still
|
// self.$list.options({items: self.options.events}) still
|
||||||
// registers as a change
|
// registers as a change
|
||||||
items: Ox.clone(self.options.events, true),
|
items: Ox.clone(self.options.events, true),
|
||||||
|
keys: ['matches'],
|
||||||
|
max: 1,
|
||||||
|
min: 0,
|
||||||
pageLength: self.options.pageLength,
|
pageLength: self.options.pageLength,
|
||||||
scrollbarVisible: true,
|
scrollbarVisible: true,
|
||||||
|
selected: self.options.selected ? [self.options.selected] : [],
|
||||||
sort: self.options.sort
|
sort: self.options.sort
|
||||||
})
|
})
|
||||||
.bindEvent({
|
.bindEvent({
|
||||||
|
@ -208,7 +243,7 @@ Ox.ListCalendar = function(options, self) {
|
||||||
self.$calendar.zoom(-1);
|
self.$calendar.zoom(-1);
|
||||||
},
|
},
|
||||||
key_shift_0: function() {
|
key_shift_0: function() {
|
||||||
self.$calendar.zoomToPlace();
|
self.$calendar.zoomToEvent();
|
||||||
},
|
},
|
||||||
load: function() {
|
load: function() {
|
||||||
that.triggerEvent('loadlist');
|
that.triggerEvent('loadlist');
|
||||||
|
@ -234,7 +269,7 @@ Ox.ListCalendar = function(options, self) {
|
||||||
date: new Date(0),
|
date: new Date(0),
|
||||||
//events: Ox.clone(self.options.events, true),
|
//events: Ox.clone(self.options.events, true),
|
||||||
events: self.options.events.filter(function(event) {
|
events: self.options.events.filter(function(event) {
|
||||||
return !!event.start;
|
return !!event.type;
|
||||||
}),
|
}),
|
||||||
height: self.options.height,
|
height: self.options.height,
|
||||||
showControls: self.options.showControls,
|
showControls: self.options.showControls,
|
||||||
|
@ -279,11 +314,15 @@ Ox.ListCalendar = function(options, self) {
|
||||||
.css({float: 'left', margin: '4px 4px 4px 0'})
|
.css({float: 'left', margin: '4px 4px 4px 0'})
|
||||||
.bindEvent({
|
.bindEvent({
|
||||||
click: function() {
|
click: function() {
|
||||||
self.$calendar.options({selected: null});
|
self.$list.options({selected: []});
|
||||||
|
// FIXME: list doesn't fire select event
|
||||||
|
selectItem({ids: []});
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
.appendTo(self.$eventTitle);
|
.appendTo(self.$eventTitle);
|
||||||
|
|
||||||
|
self.$eventData = Ox.Element();
|
||||||
|
|
||||||
self.$eventForm = Ox.Form({
|
self.$eventForm = Ox.Form({
|
||||||
items: [
|
items: [
|
||||||
self.$nameInput = Ox.Input({
|
self.$nameInput = Ox.Input({
|
||||||
|
@ -345,8 +384,11 @@ Ox.ListCalendar = function(options, self) {
|
||||||
Ox.forEach(self.options.events, function(event) {
|
Ox.forEach(self.options.events, function(event) {
|
||||||
Ox.forEach(values, function(value) {
|
Ox.forEach(values, function(value) {
|
||||||
if (
|
if (
|
||||||
|
event.type
|
||||||
|
&& (
|
||||||
event.name == data.data.value
|
event.name == data.data.value
|
||||||
|| event.alternativeNames.indexOf(data.data.value) > -1
|
|| event.alternativeNames.indexOf(data.data.value) > -1
|
||||||
|
)
|
||||||
) {
|
) {
|
||||||
exists = value;
|
exists = value;
|
||||||
return false;
|
return false;
|
||||||
|
@ -376,7 +418,21 @@ Ox.ListCalendar = function(options, self) {
|
||||||
editEvent('end', data.data.value);
|
editEvent('end', data.data.value);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
});
|
})
|
||||||
|
.appendTo(self.$eventData);
|
||||||
|
|
||||||
|
if (self.options.hasMatches) {
|
||||||
|
self.$matchesInput = Ox.Input({
|
||||||
|
disabled: true,
|
||||||
|
id: 'matches',
|
||||||
|
label: 'Matches',
|
||||||
|
labelWidth: 64,
|
||||||
|
type: 'int',
|
||||||
|
width: 240
|
||||||
|
})
|
||||||
|
.css({margin: '8px'})
|
||||||
|
.appendTo(self.$eventData);
|
||||||
|
}
|
||||||
|
|
||||||
self.$eventStatusbar = Ox.Bar({
|
self.$eventStatusbar = Ox.Bar({
|
||||||
size: 24
|
size: 24
|
||||||
|
@ -384,9 +440,9 @@ Ox.ListCalendar = function(options, self) {
|
||||||
|
|
||||||
self.$newEventButton = Ox.Button({
|
self.$newEventButton = Ox.Button({
|
||||||
title: 'New Event',
|
title: 'New Event',
|
||||||
width: 96
|
width: 70
|
||||||
})
|
})
|
||||||
.css({float: 'left', margin: '4px 2px 4px 4px'})
|
.css({float: 'left', margin: '4px'})
|
||||||
.bindEvent({
|
.bindEvent({
|
||||||
click: addEvent
|
click: addEvent
|
||||||
})
|
})
|
||||||
|
@ -394,19 +450,39 @@ Ox.ListCalendar = function(options, self) {
|
||||||
|
|
||||||
self.$removeEventButton = Ox.Button({
|
self.$removeEventButton = Ox.Button({
|
||||||
title: 'Remove Event',
|
title: 'Remove Event',
|
||||||
width: 96
|
width: 90
|
||||||
})
|
})
|
||||||
.css({float: 'right', margin: '4px 4px 4px 2px'})
|
.css({float: 'right', margin: '4px'})
|
||||||
.bindEvent({
|
.bindEvent({
|
||||||
click: removeEvent
|
click: removeEvent
|
||||||
})
|
})
|
||||||
.hide()
|
.hide()
|
||||||
.appendTo(self.$eventStatusbar);
|
.appendTo(self.$eventStatusbar);
|
||||||
|
|
||||||
|
if (self.options.mode == 'define') {
|
||||||
|
self.$defineEventButton = Ox.Button({
|
||||||
|
title: 'Define Event',
|
||||||
|
width: 80
|
||||||
|
})
|
||||||
|
.css({float: 'right', margin: '4px 0 4px 0'})
|
||||||
|
.bindEvent({
|
||||||
|
click: function() {
|
||||||
|
if (this.options('title') == 'Define Event') {
|
||||||
|
defineEvent();
|
||||||
|
} else {
|
||||||
|
clearEvent();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
})
|
||||||
|
.hide()
|
||||||
|
.appendTo(self.$eventStatusbar);
|
||||||
|
}
|
||||||
|
|
||||||
|
that.$element.replaceWith(
|
||||||
that.$element = Ox.SplitPanel({
|
that.$element = Ox.SplitPanel({
|
||||||
elements: [
|
elements: [
|
||||||
{
|
{
|
||||||
collapsible: true,
|
collapsible: self.options.collapsible,
|
||||||
element: Ox.SplitPanel({
|
element: Ox.SplitPanel({
|
||||||
elements: [
|
elements: [
|
||||||
{
|
{
|
||||||
|
@ -431,7 +507,7 @@ Ox.ListCalendar = function(options, self) {
|
||||||
element: self.$calendar,
|
element: self.$calendar,
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
collapsible: true,
|
collapsible: self.options.collapsible,
|
||||||
element: Ox.SplitPanel({
|
element: Ox.SplitPanel({
|
||||||
elements: [
|
elements: [
|
||||||
{
|
{
|
||||||
|
@ -439,7 +515,7 @@ Ox.ListCalendar = function(options, self) {
|
||||||
size: 24
|
size: 24
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
element: self.$eventForm
|
element: self.$eventData
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
element: self.$eventStatusbar,
|
element: self.$eventStatusbar,
|
||||||
|
@ -450,20 +526,25 @@ Ox.ListCalendar = function(options, self) {
|
||||||
})
|
})
|
||||||
.bindEvent({
|
.bindEvent({
|
||||||
resize: function(data) {
|
resize: function(data) {
|
||||||
self.$placeTitleName.options({width: data.size - 48});
|
self.$eventTitleName.options({width: data.size - 48});
|
||||||
// fixme: pass width through form
|
// fixme: pass width through form
|
||||||
self.$placeFormItems.forEach(function($item) {
|
/*
|
||||||
|
self.$eventFormItems.forEach(function($item) {
|
||||||
$item.options({width: data.size - 16});
|
$item.options({width: data.size - 16});
|
||||||
});
|
});
|
||||||
|
*/
|
||||||
}
|
}
|
||||||
}),
|
}),
|
||||||
resizable: true,
|
resizable: true,
|
||||||
resize: [204, 256, 384],
|
resize: [256, 384],
|
||||||
size: 256
|
size: 256
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
orientation: 'horizontal'
|
orientation: 'horizontal'
|
||||||
});
|
})
|
||||||
|
.addClass('OxListMap')
|
||||||
|
.$element
|
||||||
|
);
|
||||||
|
|
||||||
function addEvent() {
|
function addEvent() {
|
||||||
Ox.Log('Calendar', 'ADD', self.$calendar.getBounds())
|
Ox.Log('Calendar', 'ADD', self.$calendar.getBounds())
|
||||||
|
@ -494,17 +575,53 @@ Ox.ListCalendar = function(options, self) {
|
||||||
self.$nameInput.focusInput(true);
|
self.$nameInput.focusInput(true);
|
||||||
} else {
|
} else {
|
||||||
// FIXME
|
// FIXME
|
||||||
alert(result.status.text);
|
// alert(result.status.text);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function clearEvent() {
|
||||||
|
var event = Ox.getObjectById(self.options.events, self.options.selected),
|
||||||
|
values = {
|
||||||
|
id: self.options.selected,
|
||||||
|
alternativeNames: [], type: '',
|
||||||
|
start: '', end: ''
|
||||||
|
};
|
||||||
|
self.$defineEventButton.options({disabled: true, title: 'Clear Event'});
|
||||||
|
self.options.editEvent(values, function() {
|
||||||
|
Ox.forEach(values, function(value, key) {
|
||||||
|
self.$list.value(self.options.selected, key, value);
|
||||||
|
});
|
||||||
|
self.$list.reloadList();
|
||||||
|
self.$calendar.removeEvent();
|
||||||
|
self.$eventForm.hide();
|
||||||
|
self.$defineEventButton.options({disabled: false, title: 'Define Event'});
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
function defineEvent() {
|
||||||
|
var bounds = self.$calendar.getBounds(),
|
||||||
|
middle = +self.$calendar.options('date'),
|
||||||
|
startTime = +new Date((+bounds.startTime + middle) / 2),
|
||||||
|
endTime = +new Date((+bounds.endTime + middle) / 2),
|
||||||
|
event = Ox.getObjectById(self.options.events, self.options.selected);
|
||||||
|
event.name = self.$list.value(self.options.selected, 'name');
|
||||||
|
event.alternativeNames = [];
|
||||||
|
event.type = 'other';
|
||||||
|
event.start = Ox.formatDate(startTime, '%Y-%m-%d %H:%M:%S', true);
|
||||||
|
event.end = Ox.formatDate(endTime, '%Y-%m-%d %H:%M:%S', true);
|
||||||
|
self.$list.options({items: Ox.clone(self.options.events, true)});
|
||||||
|
self.$calendar.addEvent(event);
|
||||||
|
self.$defineEventButton.options({title: 'Clear Event'});
|
||||||
|
}
|
||||||
|
|
||||||
function editEvent(key, value) {
|
function editEvent(key, value) {
|
||||||
var id = self.selectedEvent,
|
var id = self.selectedEvent,
|
||||||
index = Ox.getIndexById(self.options.events, id),
|
index = Ox.getIndexById(self.options.events, id),
|
||||||
data = {id: id};
|
data = {id: id};
|
||||||
data[key] = value;
|
data[key] = value;
|
||||||
self.options.editEvent(data, function(result) {
|
self.options.editEvent(data, function(result) {
|
||||||
|
Ox.print('EDIT EVENT::', result.data)
|
||||||
if (result.status.code == 200) {
|
if (result.status.code == 200) {
|
||||||
self.options.events[index][key] = value;
|
self.options.events[index][key] = value;
|
||||||
self.$list.value(id, key, value);
|
self.$list.value(id, key, value);
|
||||||
|
@ -521,6 +638,11 @@ Ox.ListCalendar = function(options, self) {
|
||||||
)
|
)
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
self.$list.value(id, 'matches', result.data.matches);
|
||||||
|
self.$matchesInput.value(result.data.matches);
|
||||||
|
self.options.mode == 'define' && self.$removeEventButton.options({
|
||||||
|
disabled: !!result.data.matches
|
||||||
|
});
|
||||||
} else {
|
} else {
|
||||||
// ...
|
// ...
|
||||||
}
|
}
|
||||||
|
@ -566,39 +688,72 @@ Ox.ListCalendar = function(options, self) {
|
||||||
self.$calendar.removeEvent();
|
self.$calendar.removeEvent();
|
||||||
selectEvent({});
|
selectEvent({});
|
||||||
} else {
|
} else {
|
||||||
alert(result.status.text);
|
// FIXME
|
||||||
|
// alert(result.status.text);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
function selectEvent(event) {
|
function selectEvent(event) {
|
||||||
self.$list.options({
|
// Select event on calendar
|
||||||
selected: event.id ? [event.id] : []
|
var isUndefined = !!self.options.selected
|
||||||
});
|
&& !self.$list.value(self.options.selected, 'type');
|
||||||
if (event.id) {
|
self.selectedEvent = event.id || '';
|
||||||
var end = event
|
if (!self.selectedPlace && isUndefined) {
|
||||||
self.selectedEvent = event.id;
|
// deselect triggered by selecting an undefined item,
|
||||||
self.$eventName.options({title: event.name});
|
// so do nothing
|
||||||
self.$eventTitle.show();
|
|
||||||
Ox.print('VALUES:', Ox.extend({}, event, {
|
|
||||||
end: event.current ? '' : event.end
|
|
||||||
}))
|
|
||||||
self.$eventForm.values(Ox.extend({}, event, {
|
|
||||||
end: event.current ? '' : event.end
|
|
||||||
})).show();
|
|
||||||
self.$removeEventButton.show();
|
|
||||||
} else {
|
} else {
|
||||||
self.selectedEvent = null;
|
self.options.selected = self.selectedEvent;
|
||||||
self.$eventTitle.hide();
|
self.$list.options({
|
||||||
self.$eventForm.hide();
|
selected: self.options.selected ? [self.options.selected] : []
|
||||||
self.$removeEventButton.hide();
|
});
|
||||||
|
selectItem({ids: self.$list.options('selected')});
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
function selectItem(data) {
|
function selectItem(data) {
|
||||||
var id = data.ids.length ? data.ids[0] : null;
|
// Select item in list
|
||||||
self.$calendar.options({selected: id});
|
Ox.print('selectItem', data);
|
||||||
id && self.$calendar.panToEvent();
|
var event, isUndefined, selectedEvent;
|
||||||
|
self.options.selected = data.ids.length ? data.ids[0] : '';
|
||||||
|
event = self.options.selected
|
||||||
|
? self.$list.value(self.options.selected) : {};
|
||||||
|
isUndefined = !!self.options.selected
|
||||||
|
&& !self.$list.value(self.options.selected, 'type');
|
||||||
|
selectedEvent = self.options.selected && !isUndefined
|
||||||
|
? self.options.selected : '';
|
||||||
|
self.$calendar.options({selected: selectedEvent});
|
||||||
|
selectedEvent && self.$calendar.panToEvent();
|
||||||
|
Ox.print('EVENT', event, self.options.hasMatches)
|
||||||
|
if (self.options.selected) {
|
||||||
|
self.$eventName.options({title: event.name || ''});
|
||||||
|
self.$eventTitle.show();
|
||||||
|
if (!isUndefined) {
|
||||||
|
self.$eventForm.values(Ox.extend({}, event, {
|
||||||
|
end: event.current ? '' : event.end
|
||||||
|
})).show();
|
||||||
|
} else {
|
||||||
|
self.$eventForm.hide();
|
||||||
|
}
|
||||||
|
self.options.hasMatches && self.$matchesInput.value(event.matches || 0).show();
|
||||||
|
self.options.mode == 'define' && self.$defineEventButton.options({
|
||||||
|
title: isUndefined ? 'Define Event' : 'Clear Event'
|
||||||
|
}).show();
|
||||||
|
self.$defineEventButton.options({
|
||||||
|
disabled: !event.matches,
|
||||||
|
title: isUndefined ? 'Define Event' : 'Clear Event'
|
||||||
|
}).show();
|
||||||
|
self.$removeEventButton.options({
|
||||||
|
disabled: self.options.mode == 'define' && !!event.matches
|
||||||
|
}).show();
|
||||||
|
} else {
|
||||||
|
self.$eventTitle.hide();
|
||||||
|
self.$eventForm.hide();
|
||||||
|
self.options.hasMatches && self.$matchesInput.hide();
|
||||||
|
self.options.mode == 'define' && self.$defineEventButton.hide();
|
||||||
|
self.$removeEventButton.hide();
|
||||||
|
}
|
||||||
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
function updateList(key, value) {
|
function updateList(key, value) {
|
||||||
|
|
|
@ -1390,7 +1390,6 @@ Ox.List = function(options, self) {
|
||||||
updateQuery();
|
updateQuery();
|
||||||
}
|
}
|
||||||
} else if (key == 'selected') {
|
} else if (key == 'selected') {
|
||||||
//Ox.Log('List', 'setOption selected', value)
|
|
||||||
previousSelected = self.selected;
|
previousSelected = self.selected;
|
||||||
setSelected(value);
|
setSelected(value);
|
||||||
// fixme: the following was added in order
|
// fixme: the following was added in order
|
||||||
|
|
|
@ -585,7 +585,7 @@ Ox.TextList = function(options, self) {
|
||||||
}
|
}
|
||||||
|
|
||||||
function getCell(id, key) {
|
function getCell(id, key) {
|
||||||
Ox.Log('List', 'getCell', id, key)
|
Ox.print('List', 'getCell', id, key)
|
||||||
var $item = getItem(id);
|
var $item = getItem(id);
|
||||||
key = key || ''; // fixme: what is this?
|
key = key || ''; // fixme: what is this?
|
||||||
return $($item.find('.OxCell.OxColumn' + Ox.toTitleCase(key))[0]);
|
return $($item.find('.OxCell.OxColumn' + Ox.toTitleCase(key))[0]);
|
||||||
|
|
|
@ -23,9 +23,10 @@ Ox.ListMap = function(options, self) {
|
||||||
var that = Ox.Element({}, self)
|
var that = Ox.Element({}, self)
|
||||||
.defaults({
|
.defaults({
|
||||||
addPlace: null,
|
addPlace: null,
|
||||||
editPlace: null,
|
|
||||||
collapsible: false,
|
collapsible: false,
|
||||||
|
editPlace: null,
|
||||||
getMatches: null,
|
getMatches: null,
|
||||||
|
hasMatches: false,
|
||||||
height: 256,
|
height: 256,
|
||||||
labels: false,
|
labels: false,
|
||||||
mode: 'add',
|
mode: 'add',
|
||||||
|
@ -73,7 +74,7 @@ Ox.ListMap = function(options, self) {
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
format: function(value, data) {
|
format: function(value, data) {
|
||||||
return data.geoname
|
return data.type
|
||||||
? $('<img>')
|
? $('<img>')
|
||||||
.attr({
|
.attr({
|
||||||
src: Ox.getFlagByGeoname(data.geoname, 16)
|
src: Ox.getFlagByGeoname(data.geoname, 16)
|
||||||
|
@ -143,7 +144,7 @@ Ox.ListMap = function(options, self) {
|
||||||
format: function(value, data) {
|
format: function(value, data) {
|
||||||
return data.type
|
return data.type
|
||||||
? value
|
? value
|
||||||
: $('<span>').addClass('OxWarning').html(value)
|
: $('<span>').addClass('OxWarning').html(value);
|
||||||
},
|
},
|
||||||
id: 'name',
|
id: 'name',
|
||||||
operator: '+',
|
operator: '+',
|
||||||
|
@ -264,16 +265,17 @@ Ox.ListMap = function(options, self) {
|
||||||
title: 'Date Modified',
|
title: 'Date Modified',
|
||||||
visible: false,
|
visible: false,
|
||||||
width: 128,
|
width: 128,
|
||||||
},
|
}
|
||||||
{
|
];
|
||||||
|
|
||||||
|
self.options.hasMatches && self.columns.push({
|
||||||
align: 'right',
|
align: 'right',
|
||||||
id: 'matches',
|
id: 'matches',
|
||||||
operator: '-',
|
operator: '-',
|
||||||
title: 'Matches',
|
title: 'Matches',
|
||||||
visible: false,
|
visible: true,
|
||||||
width: 64,
|
width: 64
|
||||||
}
|
});
|
||||||
];
|
|
||||||
|
|
||||||
self.$listToolbar = Ox.Bar({
|
self.$listToolbar = Ox.Bar({
|
||||||
size: 24
|
size: 24
|
||||||
|
@ -313,19 +315,14 @@ Ox.ListMap = function(options, self) {
|
||||||
]
|
]
|
||||||
})
|
})
|
||||||
.css({float: 'right', margin: '4px'})
|
.css({float: 'right', margin: '4px'})
|
||||||
.bindEvent({
|
|
||||||
change: function(data) {
|
|
||||||
|
|
||||||
}
|
|
||||||
})
|
|
||||||
.appendTo(self.$listToolbar);
|
.appendTo(self.$listToolbar);
|
||||||
|
|
||||||
self.$list = Ox.TextList({
|
self.$list = Ox.TextList({
|
||||||
columns: self.columns,
|
columns: self.columns,
|
||||||
columnsRemovable: true,
|
columnsRemovable: true,
|
||||||
columnsVisible: true,
|
columnsVisible: true,
|
||||||
//items: Ox.clone(self.options.places),
|
items: Ox.clone(self.options.places),
|
||||||
items: self.options.places,
|
//items: self.options.places,
|
||||||
// area needed for icon, geoname needed for flag
|
// area needed for icon, geoname needed for flag
|
||||||
keys: ['area', 'geoname', 'matches'],
|
keys: ['area', 'geoname', 'matches'],
|
||||||
max: 1,
|
max: 1,
|
||||||
|
@ -457,31 +454,23 @@ Ox.ListMap = function(options, self) {
|
||||||
.css({float: 'left', margin: '4px'})
|
.css({float: 'left', margin: '4px'})
|
||||||
.bindEvent({
|
.bindEvent({
|
||||||
click: function() {
|
click: function() {
|
||||||
self.$map.options({selected: null});
|
self.$list.options({selected: []});
|
||||||
|
// FIXME: list doesn't fire select event
|
||||||
|
selectItem({ids: []});
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
.appendTo(self.$placeTitle);
|
.appendTo(self.$placeTitle);
|
||||||
|
|
||||||
|
self.$placeData = Ox.Element();
|
||||||
|
|
||||||
|
self.$placeForm = Ox.Form({
|
||||||
|
items: Ox.merge([
|
||||||
self.$nameInput = Ox.Input({
|
self.$nameInput = Ox.Input({
|
||||||
id: 'name',
|
id: 'name',
|
||||||
label: 'Name',
|
label: 'Name',
|
||||||
labelWidth: 64,
|
labelWidth: 64,
|
||||||
width: 240
|
width: 240
|
||||||
}).bindEvent({
|
}),
|
||||||
change: function(data) {
|
|
||||||
var isResult = self.selectedPlace[0] == '_';
|
|
||||||
!isResult && self.$list.value(self.selectedPlace, 'name', data.value);
|
|
||||||
if (!self.isAsync) {
|
|
||||||
Ox.getObjectById(
|
|
||||||
self.options.places, self.selectedPlace
|
|
||||||
).name = data.value;
|
|
||||||
} else {
|
|
||||||
!isResult && editPlace(['name']);
|
|
||||||
}
|
|
||||||
self.$map.value(self.selectedPlace, 'name', data.value);
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
self.$alternativeNamesInput = Ox.ArrayInput({
|
self.$alternativeNamesInput = Ox.ArrayInput({
|
||||||
id: 'alternativeNames',
|
id: 'alternativeNames',
|
||||||
label: 'Alternative Names',
|
label: 'Alternative Names',
|
||||||
|
@ -489,54 +478,13 @@ Ox.ListMap = function(options, self) {
|
||||||
//sort: true,
|
//sort: true,
|
||||||
values: [],
|
values: [],
|
||||||
width: 240
|
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);
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
self.$geonameInput = Ox.Input({
|
self.$geonameInput = Ox.Input({
|
||||||
id: 'geoname',
|
id: 'geoname',
|
||||||
label: 'Geoname',
|
label: 'Geoname',
|
||||||
labelWidth: 64,
|
labelWidth: 64,
|
||||||
width: 240
|
width: 240
|
||||||
}).bindEvent({
|
}),
|
||||||
change: function(data) {
|
|
||||||
var geoname = data.value,
|
|
||||||
country = Ox.getCountryByGeoname(geoname),
|
|
||||||
countryCode = country ? country.code : '',
|
|
||||||
isResult = self.selectedPlace[0] == '_';
|
|
||||||
Ox.print('CHANGE', geoname, country, countryCode, self.isAsync);
|
|
||||||
self.$placeFlag.attr({
|
|
||||||
src: Ox.getFlagByGeoname(geoname, 16)
|
|
||||||
});
|
|
||||||
self.$placeName.options({title: geoname});
|
|
||||||
self.$placeForm.values({countryCode: countryCode});
|
|
||||||
if (!self.isAsync) {
|
|
||||||
if (!isResult) {
|
|
||||||
self.$list.value(self.selectedPlace, 'geoname', geoname);
|
|
||||||
self.$list.value(self.selectedPlace, 'countryCode', countryCode);
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
!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(),
|
||||||
|
@ -554,16 +502,6 @@ Ox.ListMap = function(options, self) {
|
||||||
label: 'Type',
|
label: 'Type',
|
||||||
labelWidth: 64,
|
labelWidth: 64,
|
||||||
width: 240
|
width: 240
|
||||||
}).bindEvent({
|
|
||||||
change: function(data) {
|
|
||||||
var isResult = self.selectedPlace[0] == '_';
|
|
||||||
if (!self.isAsync) {
|
|
||||||
// ...
|
|
||||||
} else {
|
|
||||||
!isResult && editPlace(['type'])
|
|
||||||
}
|
|
||||||
self.$map.value(self.selectedPlace, 'type', data.value);
|
|
||||||
}
|
|
||||||
})
|
})
|
||||||
], ['Latitude', 'Longitude', 'South', 'West', 'North', 'East'].map(function(v) {
|
], ['Latitude', 'Longitude', 'South', 'West', 'North', 'East'].map(function(v) {
|
||||||
var id = (
|
var id = (
|
||||||
|
@ -580,34 +518,75 @@ Ox.ListMap = function(options, self) {
|
||||||
max: max,
|
max: max,
|
||||||
type: 'float',
|
type: 'float',
|
||||||
width: 240
|
width: 240
|
||||||
})
|
|
||||||
.bindEvent({
|
|
||||||
blur: function(data) {
|
|
||||||
///*
|
|
||||||
// fixme: if type is set, no change event fires
|
|
||||||
var isResult = self.selectedPlace[0] == '_';
|
|
||||||
if (!self.isAsync) {
|
|
||||||
// ...
|
|
||||||
} else {
|
|
||||||
!isResult && editPlace([v])
|
|
||||||
}
|
|
||||||
self.$map.value(self.selectedPlace, id, parseFloat(data.value));
|
|
||||||
//*/
|
|
||||||
}
|
|
||||||
});
|
});
|
||||||
}), [
|
}),
|
||||||
|
[
|
||||||
self.$areaInput = Ox.Input({
|
self.$areaInput = Ox.Input({
|
||||||
id: 'area',
|
id: 'area',
|
||||||
type: 'float'
|
type: 'float'
|
||||||
}).hide()
|
}).hide()
|
||||||
]);
|
]),
|
||||||
|
|
||||||
self.$placeForm = Ox.Form({
|
|
||||||
items: self.$placeFormItems,
|
|
||||||
width: 240
|
width: 240
|
||||||
})
|
})
|
||||||
.css({margin: '8px'})
|
.css({margin: '8px'})
|
||||||
.hide();
|
.hide()
|
||||||
|
.bindEvent({
|
||||||
|
change: function(data) {
|
||||||
|
var isResult = self.selectedPlace[0] == '_';
|
||||||
|
if (data.id == 'name') {
|
||||||
|
!isResult && self.$list.value(self.selectedPlace, 'name', data.data.value);
|
||||||
|
if (!self.isAsync) {
|
||||||
|
Ox.getObjectById(
|
||||||
|
self.options.places, self.selectedPlace
|
||||||
|
).name = data.data.value;
|
||||||
|
} else {
|
||||||
|
!isResult && editPlace(['name']);
|
||||||
|
}
|
||||||
|
self.$map.value(self.selectedPlace, 'name', data.data.value);
|
||||||
|
} else if (data.id == 'alternativeNames') {
|
||||||
|
if (!self.isAsync) {
|
||||||
|
// ...
|
||||||
|
} else {
|
||||||
|
!isResult && editPlace(['alternativeNames'])
|
||||||
|
}
|
||||||
|
self.$map.value(self.selectedPlace, 'alternativeNames', data.data.value);
|
||||||
|
} else if (data.id == 'geoname') {
|
||||||
|
var geoname = data.data.value,
|
||||||
|
country = Ox.getCountryByGeoname(geoname),
|
||||||
|
countryCode = country ? country.code : '';
|
||||||
|
self.$placeFlag.attr({
|
||||||
|
src: Ox.getFlagByGeoname(geoname, 16)
|
||||||
|
});
|
||||||
|
self.$placeName.options({title: geoname});
|
||||||
|
self.$placeForm.values({countryCode: countryCode});
|
||||||
|
if (!self.isAsync) {
|
||||||
|
if (!isResult) {
|
||||||
|
self.$list.value(self.selectedPlace, 'geoname', geoname);
|
||||||
|
self.$list.value(self.selectedPlace, 'countryCode', countryCode);
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
!isResult && editPlace(['countryCode', 'geoname']);
|
||||||
|
}
|
||||||
|
self.$map.value(self.selectedPlace, 'countryCode', countryCode);
|
||||||
|
self.$map.value(self.selectedPlace, 'geoname', geoname);
|
||||||
|
} else if (data.id == 'type') {
|
||||||
|
if (!self.isAsync) {
|
||||||
|
// ...
|
||||||
|
} else {
|
||||||
|
!isResult && editPlace(['type'])
|
||||||
|
}
|
||||||
|
self.$map.value(self.selectedPlace, 'type', data.data.value);
|
||||||
|
} else { // lat, lng, south, west, north, east
|
||||||
|
if (!self.isAsync) {
|
||||||
|
// ...
|
||||||
|
} else {
|
||||||
|
!isResult && editPlace([data.id])
|
||||||
|
}
|
||||||
|
self.$map.value(self.selectedPlace, data.id, parseFloat(data.data.value));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
})
|
||||||
|
.appendTo(self.$placeData);
|
||||||
|
|
||||||
self.$areaKmInput = Ox.Input({
|
self.$areaKmInput = Ox.Input({
|
||||||
disabled: true,
|
disabled: true,
|
||||||
|
@ -617,10 +596,11 @@ Ox.ListMap = function(options, self) {
|
||||||
textAlign: 'right',
|
textAlign: 'right',
|
||||||
width: 240
|
width: 240
|
||||||
})
|
})
|
||||||
.css({margin: '4px 0 4px 0'})
|
.css({margin: '8px 8px 0 8px'})
|
||||||
.appendTo(self.$placeForm);
|
.hide()
|
||||||
|
.appendTo(self.$placeData);
|
||||||
|
|
||||||
if (self.options.getMatches) {
|
if (self.options.hasMatches) {
|
||||||
self.$matchesInput = Ox.Input({
|
self.$matchesInput = Ox.Input({
|
||||||
disabled: true,
|
disabled: true,
|
||||||
id: 'matches',
|
id: 'matches',
|
||||||
|
@ -629,8 +609,9 @@ Ox.ListMap = function(options, self) {
|
||||||
type: 'int',
|
type: 'int',
|
||||||
width: 240
|
width: 240
|
||||||
})
|
})
|
||||||
.css({margin: '8px 0 4px 0'})
|
.css({margin: '8px'})
|
||||||
.appendTo(self.$placeForm);
|
.hide()
|
||||||
|
.appendTo(self.$placeData);
|
||||||
}
|
}
|
||||||
|
|
||||||
self.$placeStatusbar = Ox.Bar({
|
self.$placeStatusbar = Ox.Bar({
|
||||||
|
@ -685,16 +666,6 @@ Ox.ListMap = function(options, self) {
|
||||||
.appendTo(self.$placeStatusbar);
|
.appendTo(self.$placeStatusbar);
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
|
||||||
self.$revertButton = Ox.Button({
|
|
||||||
title: 'Revert',
|
|
||||||
width: 96
|
|
||||||
})
|
|
||||||
.css({float: 'right', margin: '4px 4px 4px 2px'})
|
|
||||||
.hide()
|
|
||||||
.appendTo(self.$placeStatusbar);
|
|
||||||
*/
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
self.mapResize = [
|
self.mapResize = [
|
||||||
Math.round(self.options.width * 0.25),
|
Math.round(self.options.width * 0.25),
|
||||||
|
@ -757,7 +728,7 @@ Ox.ListMap = function(options, self) {
|
||||||
size: 24
|
size: 24
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
element: self.$placeForm
|
element: self.$placeData
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
element: self.$placeStatusbar,
|
element: self.$placeStatusbar,
|
||||||
|
@ -803,9 +774,7 @@ Ox.ListMap = function(options, self) {
|
||||||
self.$map.addPlace(place);
|
self.$map.addPlace(place);
|
||||||
self.$addPlaceButton.options({title: 'Remove Place'});
|
self.$addPlaceButton.options({title: 'Remove Place'});
|
||||||
//setStatus();
|
//setStatus();
|
||||||
}
|
} else {
|
||||||
//that.triggerEvent('addplace', {place: place});
|
|
||||||
if (self.isAsync) {
|
|
||||||
self.$addPlaceButton.options({disabled: true, title: 'Adding...'});
|
self.$addPlaceButton.options({disabled: true, title: 'Adding...'});
|
||||||
self.options.addPlace(place, function(result) {
|
self.options.addPlace(place, function(result) {
|
||||||
if (result.status.code == 200) {
|
if (result.status.code == 200) {
|
||||||
|
@ -813,17 +782,22 @@ Ox.ListMap = function(options, self) {
|
||||||
self.selectedPlace = place.id;
|
self.selectedPlace = place.id;
|
||||||
self.$list.reloadList().options({selected: [place.id]});
|
self.$list.reloadList().options({selected: [place.id]});
|
||||||
self.$map.addPlace(place);
|
self.$map.addPlace(place);
|
||||||
self.$addPlaceButton.options({disabled: false, title: 'Remove Place'});
|
self.options.hasMatches && self.$matchesInput.value(
|
||||||
} else {
|
result.data.matches
|
||||||
if (result.data.names) {
|
).show();
|
||||||
|
self.options.mode == 'define' && self.$definePlaceButton.options({
|
||||||
|
disabled: !result.data.matches,
|
||||||
|
title: 'Clear Place'
|
||||||
|
}).show();
|
||||||
|
self.$addPlaceButton.options({
|
||||||
|
disabled: false,
|
||||||
|
title: 'Remove Place'
|
||||||
|
}).show();
|
||||||
|
} else if (result.status.code == 409) {
|
||||||
if (result.data.names.indexOf(self.$nameInput.value()) > -1) {
|
if (result.data.names.indexOf(self.$nameInput.value()) > -1) {
|
||||||
self.$nameInput.addClass('OxError');
|
self.$nameInput.addClass('OxError');
|
||||||
}
|
}
|
||||||
self.$alternativeNamesInput.setErrors(result.data.names);
|
self.$alternativeNamesInput.setErrors(result.data.names);
|
||||||
}
|
|
||||||
if (result.data.geoname) {
|
|
||||||
self.$geonameInput.addClass('OxError');
|
|
||||||
}
|
|
||||||
self.$addPlaceButton.options({disabled: false, title: 'Add Place'});
|
self.$addPlaceButton.options({disabled: false, title: 'Add Place'});
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
@ -840,17 +814,18 @@ Ox.ListMap = function(options, self) {
|
||||||
self.$definePlaceButton.options({disabled: true, title: 'Clearing...'});
|
self.$definePlaceButton.options({disabled: true, title: 'Clearing...'});
|
||||||
self.options.editPlace(values, function() {
|
self.options.editPlace(values, function() {
|
||||||
self.$list.reloadList();
|
self.$list.reloadList();
|
||||||
self.$map.removePlace();
|
self.$map.removePlace().options({selected: ''});
|
||||||
self.$findPlaceButton.show();
|
self.$findPlaceButton.show();
|
||||||
self.$placeFlag.hide();
|
self.$placeFlag.hide();
|
||||||
self.$placeForm.hide();
|
self.$placeForm.hide();
|
||||||
|
self.$areaKmInput.hide();
|
||||||
self.$definePlaceButton.options({disabled: false, title: 'Define Place'})
|
self.$definePlaceButton.options({disabled: false, title: 'Define Place'})
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
function definePlace() {
|
function definePlace() {
|
||||||
self.$map.newPlace(); // this will call selectPlace, then editPlace
|
self.$map.newPlace(); // this will call selectPlace, then editPlace
|
||||||
self.$definePlaceButton.options({title: 'Clear Place'})
|
self.$definePlaceButton.options({title: 'Clear Place'});
|
||||||
}
|
}
|
||||||
|
|
||||||
function editPlace(keys) {
|
function editPlace(keys) {
|
||||||
|
@ -859,8 +834,19 @@ Ox.ListMap = function(options, self) {
|
||||||
return keys.indexOf(key) > -1;
|
return keys.indexOf(key) > -1;
|
||||||
});
|
});
|
||||||
values.id = self.selectedPlace;
|
values.id = self.selectedPlace;
|
||||||
self.options.editPlace(values, function() {
|
self.options.editPlace(values, function(result) {
|
||||||
if (keys.indexOf(self.$list.options('sort')[0].key) > -1) {
|
Ox.print('EDIT PLACE::', result)
|
||||||
|
if (result.status.code == 200) {
|
||||||
|
if (
|
||||||
|
keys.indexOf(self.$list.options('sort')[0].key) > -1
|
||||||
|
|| (
|
||||||
|
self.options.mode == 'define'
|
||||||
|
&& (
|
||||||
|
keys.indexOf('name') > -1
|
||||||
|
|| keys.indexOf('alternativeNames') > -1
|
||||||
|
)
|
||||||
|
)
|
||||||
|
) {
|
||||||
self.$list.reloadList();
|
self.$list.reloadList();
|
||||||
} else {
|
} else {
|
||||||
Ox.forEach(values, function(value, key) {
|
Ox.forEach(values, function(value, key) {
|
||||||
|
@ -869,17 +855,35 @@ Ox.ListMap = function(options, self) {
|
||||||
self.$map.value(values.id, key, value);
|
self.$map.value(values.id, key, value);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
self.$list.value(values.id, 'matches', result.data.matches);
|
||||||
|
}
|
||||||
|
if (self.options.mode == 'define') {
|
||||||
|
self.$findPlaceButton.hide();
|
||||||
|
self.$placeFlag.show();
|
||||||
|
}
|
||||||
|
self.options.hasMatches && self.$matchesInput.value(result.data.matches);
|
||||||
|
if (self.options.mode == 'define') {
|
||||||
|
self.$definePlaceButton.options({
|
||||||
|
disabled: !result.data.matches,
|
||||||
|
title: 'Clear Place'
|
||||||
|
});
|
||||||
|
self.$addPlaceButton.options({
|
||||||
|
disabled: !!result.data.matches
|
||||||
|
});
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
if (result.data.names.indexOf(self.$nameInput.value()) > -1) {
|
||||||
|
self.$nameInput.addClass('OxError');
|
||||||
|
}
|
||||||
|
self.$alternativeNamesInput.setErrors(result.data.names);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
if (keys.indexOf('name') > -1 || keys.indexOf('alternativeNames') > -1) {
|
|
||||||
updateMatches();
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
function findPlace() {
|
function findPlace() {
|
||||||
self.$map.options({
|
self.$map
|
||||||
find: self.$list.value(self.selectedPlace).name
|
//.options({find: ''})
|
||||||
});
|
.options({find: self.$list.value(self.options.selected, 'name')});
|
||||||
}
|
}
|
||||||
|
|
||||||
function initList(data) {
|
function initList(data) {
|
||||||
|
@ -918,98 +922,125 @@ Ox.ListMap = function(options, self) {
|
||||||
self.$addPlaceButton.options({disabled: true, title: 'Removing...'})
|
self.$addPlaceButton.options({disabled: true, title: 'Removing...'})
|
||||||
self.options.removePlace({id: self.selectedPlace}, function() {
|
self.options.removePlace({id: self.selectedPlace}, function() {
|
||||||
self.$list.options({selected: []}).reloadList(true);
|
self.$list.options({selected: []}).reloadList(true);
|
||||||
|
self.options.hasMatches && self.$matchesInput.hide();
|
||||||
self.options.mode == 'define' && self.$definePlaceButton.options({
|
self.options.mode == 'define' && self.$definePlaceButton.options({
|
||||||
disabled: true
|
disabled: true
|
||||||
});
|
});
|
||||||
self.$addPlaceButton.options({disabled: false, title: 'Add Place'})
|
self.$addPlaceButton.options({disabled: false, title: 'Add Place'});
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
self.$map.removePlace();
|
self.$map.removePlace();
|
||||||
that.triggerEvent('removeplace', {id: self.selectedPlace});
|
that.triggerEvent('removeplace', {id: self.selectedPlace});
|
||||||
}
|
}
|
||||||
|
|
||||||
function selectItem(data) {
|
function selectItem(data, place) {
|
||||||
// Select item in list
|
// Select item in list
|
||||||
|
Ox.print('selectItem', data, place);
|
||||||
var isUndefined, selectedPlace;
|
var isUndefined, selectedPlace;
|
||||||
self.options.selected = data.ids.length ? data.ids[0] : '';
|
self.options.selected = data.ids.length ? data.ids[0] : '';
|
||||||
isUndefined = !!self.options.selected
|
place = place || (
|
||||||
&& !self.$list.value(self.options.selected, 'type');
|
self.options.selected
|
||||||
|
? self.$list.value(self.options.selected) : {}
|
||||||
|
);
|
||||||
|
isUndefined = !!self.options.selected && !place.type;
|
||||||
selectedPlace = self.options.selected && !isUndefined
|
selectedPlace = self.options.selected && !isUndefined
|
||||||
? self.options.selected : null;
|
? self.options.selected : '';
|
||||||
self.$map.options({selected: selectedPlace});
|
self.$map.options({selected: selectedPlace});
|
||||||
selectedPlace && self.$map.panToPlace();
|
selectedPlace && self.$map.panToPlace();
|
||||||
if (isUndefined) {
|
if (self.options.selected) {
|
||||||
self.selectedPlace = self.options.selected;
|
self.options.mode == 'define'
|
||||||
self.$findPlaceButton.show();
|
&& self.$findPlaceButton[isUndefined ? 'show' : 'hide']();
|
||||||
self.$placeFlag.hide();
|
self.$placeFlag.attr({
|
||||||
self.$placeName.options({
|
src: Ox.getFlagByGeoname(place.geoname || '', 16)
|
||||||
title: self.$list.value(self.options.selected, 'name')
|
})[isUndefined ? 'hide' : 'show']();
|
||||||
});
|
self.$placeName.options({title: place.name || ''});
|
||||||
self.$placeTitle.show();
|
self.$placeTitle.show();
|
||||||
self.$definePlaceButton.options({
|
if (!isUndefined) {
|
||||||
title: 'Define Place'
|
self.$placeForm.values(place).show();
|
||||||
|
self.$areaKmInput.value(Ox.formatArea(place.area)).show();
|
||||||
|
} else {
|
||||||
|
self.$placeForm.hide();
|
||||||
|
self.$areaKmInput.hide();
|
||||||
|
}
|
||||||
|
self.options.hasMatches && self.$matchesInput.value(place.matches || 0).show();
|
||||||
|
self.options.mode == 'define' && self.$definePlaceButton.options({
|
||||||
|
disabled: !isUndefined && !place.matches,
|
||||||
|
title: isUndefined ? 'Define Place' : 'Clear Place'
|
||||||
}).show();
|
}).show();
|
||||||
self.$addPlaceButton.options({
|
self.$addPlaceButton.options({
|
||||||
disabled: self.$list.value(self.options.selected, 'matches') > 0,
|
disabled: self.options.mode == 'define' && !!place.matches,
|
||||||
title: 'Remove Place'
|
title: 'Remove Place'
|
||||||
}).show();
|
}).show();
|
||||||
|
} else {
|
||||||
|
self.$placeTitle.hide();
|
||||||
|
self.$placeForm.hide();
|
||||||
|
self.$areaKmInput.hide();
|
||||||
|
self.options.hasMatches && self.$matchesInput.hide();
|
||||||
|
self.options.mode == 'define' && self.$definePlaceButton.hide();
|
||||||
|
self.$addPlaceButton.hide();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
function selectPlace(place) {
|
function selectPlace(place) {
|
||||||
// Select place on map
|
// Select place on map
|
||||||
Ox.print('selectPlace', place)
|
Ox.print('selectPlace', place)
|
||||||
var isResult, isUndefined;
|
var isResult = !!place.id && place.id[0] == '_',
|
||||||
self.selectedPlace = place.id || null;
|
|
||||||
isResult = !!place.id && place.id[0] == '_';
|
|
||||||
isUndefined = !!self.options.selected
|
isUndefined = !!self.options.selected
|
||||||
&& !self.$list.value(self.options.selected, 'type');
|
&& !self.$list.value(self.options.selected, 'type'),
|
||||||
Ox.print('isResult', isResult, 'isUndefined', isUndefined, self.options.selected)
|
names;
|
||||||
if (!(isUndefined && !place.id)) {
|
self.selectedPlace = place.id || '';
|
||||||
// if isUndefined && !place.id, then we're handling the
|
|
||||||
// map deselect, which we don't want to pass to the list
|
|
||||||
self.$list.options({
|
|
||||||
selected: place.id && !isResult ? [place.id] : []
|
|
||||||
});
|
|
||||||
}
|
|
||||||
if (place.id) {
|
|
||||||
if (isResult && isUndefined) {
|
if (isResult && isUndefined) {
|
||||||
|
// define undefined place
|
||||||
self.selectedPlace = self.options.selected;
|
self.selectedPlace = self.options.selected;
|
||||||
place.id = self.options.selected;
|
|
||||||
place.name = self.$list.value(self.options.selected, 'name');
|
place.name = self.$list.value(self.options.selected, 'name');
|
||||||
Ox.print('PLACE::::::', place)
|
place.id = self.options.selected;
|
||||||
}
|
self.$map.addPlace(place);
|
||||||
self.options.mode == 'define' && self.$findPlaceButton.hide();
|
self.$placeForm.values(place).show();
|
||||||
|
self.$areaKmInput.value(Ox.formatArea(place.area)).show();
|
||||||
|
editPlace([
|
||||||
|
'geoname', 'type',
|
||||||
|
'lat', 'lng',
|
||||||
|
'south', 'west', 'north', 'east', 'area'
|
||||||
|
]);
|
||||||
|
} else if (self.selectedPlace && isResult) {
|
||||||
|
// select result place
|
||||||
|
self.$list.options({selected: []});
|
||||||
self.$placeFlag.attr({
|
self.$placeFlag.attr({
|
||||||
src: Ox.getFlagByGeoname(place.geoname || '', 16)
|
src: Ox.getFlagByGeoname(place.geoname || '', 16)
|
||||||
}).show();
|
}).show();
|
||||||
self.$placeName.options({title: place.name || ''});
|
self.$placeName.options({title: place.name || ''});
|
||||||
self.$placeTitle.show();
|
self.$placeTitle.show();
|
||||||
self.$placeForm.values(place).show();
|
self.$placeForm.values(place).show();
|
||||||
self.$areaKmInput.value(Ox.formatArea(place.area));
|
self.$areaKmInput.value(Ox.formatArea(place.area)).show();
|
||||||
self.$matchesInput.value(place.matches);
|
if (self.options.hasMatches) {
|
||||||
//updateMatches();
|
self.$matchesInput.value('').show();
|
||||||
self.options.mode == 'define' && self.$definePlaceButton.options({
|
names = Ox.filter(Ox.merge([place.name], place.alternativeNames), function(name) {
|
||||||
title: isUndefined && !isResult ? 'Define Place' : 'Clear Place'
|
return name !== '';
|
||||||
}).show();
|
});
|
||||||
self.$addPlaceButton.options({
|
self.options.getMatches(names, function(matches) {
|
||||||
disabled: self.options.mode == 'define' && place.matches > 0,
|
self.$matchesInput.value(matches);
|
||||||
title: isResult ? 'Add Place' : 'Remove Place'
|
});
|
||||||
}).show();
|
|
||||||
if (isResult && isUndefined) {
|
|
||||||
self.$map.addPlace(place);
|
|
||||||
self.$addPlaceButton.options({title: 'Remove Place'});
|
|
||||||
editPlace([
|
|
||||||
'geoname', 'type',
|
|
||||||
'lat', 'lng',
|
|
||||||
'south', 'west', 'north', 'east', 'area'
|
|
||||||
]);
|
|
||||||
}
|
}
|
||||||
} else {
|
self.options.mode == 'define' && self.$definePlaceButton.hide();
|
||||||
|
self.$addPlaceButton.options({disabled: false, title: 'Add Place'}).show();
|
||||||
|
} else if (!self.selectedPlace && !self.options.selected) {
|
||||||
|
// deselect result place
|
||||||
|
self.$placeFlag.hide();
|
||||||
self.$placeTitle.hide();
|
self.$placeTitle.hide();
|
||||||
self.$placeForm.hide();
|
self.$placeForm.hide();
|
||||||
self.options.mode == 'define' && self.$definePlaceButton.hide();
|
self.$areaKmInput.hide();
|
||||||
self.$addPlaceButton.hide();
|
self.options.hasMatches && self.$matchesInput.hide();
|
||||||
|
} else if (!self.selectedPlace && isUndefined) {
|
||||||
|
// deselect triggered by selecting an undefined item,
|
||||||
|
// so do nothing
|
||||||
|
} else {
|
||||||
|
// select or deselect existing place
|
||||||
|
self.options.selected = self.selectedPlace;
|
||||||
|
self.$list.options({
|
||||||
|
selected: self.options.selected ? [self.options.selected] : []
|
||||||
|
});
|
||||||
|
// FIXME: list doesn't fire select event
|
||||||
|
selectItem({ids: self.$list.options('selected')}, place);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1022,7 +1053,6 @@ Ox.ListMap = function(options, self) {
|
||||||
list == 'names' && !self.namesLoaded ? load() : toggle();
|
list == 'names' && !self.namesLoaded ? load() : toggle();
|
||||||
function load() {
|
function load() {
|
||||||
self.options.names(function(data) {
|
self.options.names(function(data) {
|
||||||
Ox.print('DATA IS', data);
|
|
||||||
self.$namesList.options({items: data});
|
self.$namesList.options({items: data});
|
||||||
self.namesLoaded = true;
|
self.namesLoaded = true;
|
||||||
toggle();
|
toggle();
|
||||||
|
@ -1054,24 +1084,6 @@ Ox.ListMap = function(options, self) {
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
function updateMatches() {
|
|
||||||
var names, place;
|
|
||||||
if (self.options.getMatches) {
|
|
||||||
place = self.$placeForm.values();
|
|
||||||
names = Ox.filter(Ox.merge([place.name], place.alternativeNames), function(name) {
|
|
||||||
return name !== '';
|
|
||||||
});
|
|
||||||
if (names.length) {
|
|
||||||
self.$matchesInput.value('');
|
|
||||||
self.options.getMatches(names, function(matches) {
|
|
||||||
self.$matchesInput.value(Ox.formatNumber(matches));
|
|
||||||
});
|
|
||||||
} else {
|
|
||||||
self.$matchesInput.value(0);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/*@
|
/*@
|
||||||
setOption <f> setOption
|
setOption <f> setOption
|
||||||
@*/
|
@*/
|
||||||
|
|
|
@ -536,6 +536,7 @@ Ox.Map = function(options, self) {
|
||||||
self.options.selected = place.id;
|
self.options.selected = place.id;
|
||||||
place.countryCode = country ? country.code : '';
|
place.countryCode = country ? country.code : '';
|
||||||
Ox.Log('Map', 'addP2P', data, place);
|
Ox.Log('Map', 'addP2P', data, place);
|
||||||
|
setPlaceControls(place);
|
||||||
place.marker.update();
|
place.marker.update();
|
||||||
self.places.push(place);
|
self.places.push(place);
|
||||||
self.resultPlace = null;
|
self.resultPlace = null;
|
||||||
|
@ -1204,7 +1205,9 @@ Ox.Map = function(options, self) {
|
||||||
src: Ox.getFlagByGeoname(place.geoname, 16)
|
src: Ox.getFlagByGeoname(place.geoname, 16)
|
||||||
})
|
})
|
||||||
).show();
|
).show();
|
||||||
self.$placeControls.name.options({title: place.name})
|
self.$placeControls.name.options({
|
||||||
|
title: place.name ||'<span class="OxLight">Unnamed</span>'
|
||||||
|
});
|
||||||
!isVisible && $placeControls.show().animate({opacity: 1}, 250);
|
!isVisible && $placeControls.show().animate({opacity: 1}, 250);
|
||||||
} else {
|
} else {
|
||||||
isVisible && $placeControls.animate({opacity: 0}, 250, function() {
|
isVisible && $placeControls.animate({opacity: 0}, 250, function() {
|
||||||
|
@ -1272,7 +1275,7 @@ Ox.Map = function(options, self) {
|
||||||
function submitFind(data) {
|
function submitFind(data) {
|
||||||
self.options.find = data.value;
|
self.options.find = data.value;
|
||||||
if (data.value === '') {
|
if (data.value === '') {
|
||||||
if (self.options.selected[0] == '_') {
|
if (self.options.selected && self.options.selected[0] == '_') {
|
||||||
selectPlace(null);
|
selectPlace(null);
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
|
@ -1542,6 +1545,17 @@ Ox.Map = function(options, self) {
|
||||||
that.value = function(id, key, value) {
|
that.value = function(id, key, value) {
|
||||||
// fixme: should be like the corresponding List/TextList/etc value function
|
// fixme: should be like the corresponding List/TextList/etc value function
|
||||||
Ox.print('Map', 'Map.value', id, key, value)
|
Ox.print('Map', 'Map.value', id, key, value)
|
||||||
|
if (id == self.options.selected) {
|
||||||
|
if (key == 'name') {
|
||||||
|
self.$placeControls.name.options({title: value});
|
||||||
|
} else if (key == 'geoname') {
|
||||||
|
self.$placeControls.flag.empty().append(
|
||||||
|
$('<img>').attr({
|
||||||
|
src: Ox.getFlagByGeoname(value, 16)
|
||||||
|
})
|
||||||
|
);
|
||||||
|
}
|
||||||
|
}
|
||||||
getPlaceById(id).options(key, value);
|
getPlaceById(id).options(key, value);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -245,7 +245,7 @@ Ox.MapMarker = function(options) {
|
||||||
+ Ox.getFlagByGeoname(that.place.geoname, 16)
|
+ Ox.getFlagByGeoname(that.place.geoname, 16)
|
||||||
+ '" style="float: left; margin: 1px 0 1px -1px; border-radius: 4px"/>'
|
+ '" style="float: left; margin: 1px 0 1px -1px; border-radius: 4px"/>'
|
||||||
+ '<div style="float: left; margin: 4px -1px 0 4px; font-size: 9px;">'
|
+ '<div style="float: left; margin: 4px -1px 0 4px; font-size: 9px;">'
|
||||||
+ that.place.name + '</div>'
|
+ (that.place.name || '<span class="OxLight">Unnamed</span>') + '</div>'
|
||||||
})
|
})
|
||||||
.addClass('OxMapMarkerTooltip');
|
.addClass('OxMapMarkerTooltip');
|
||||||
}
|
}
|
||||||
|
|
|
@ -13,6 +13,9 @@ body.OxThemeClassic {
|
||||||
.OxThemeClassic .OxBright {
|
.OxThemeClassic .OxBright {
|
||||||
color: rgb(0, 0, 0);
|
color: rgb(0, 0, 0);
|
||||||
}
|
}
|
||||||
|
.OxThemeClassic .OxLight {
|
||||||
|
color: rgb(128, 128, 128);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
@ -140,22 +143,22 @@ Calendar
|
||||||
inset 0 0 1px rgb(0, 0, 0),
|
inset 0 0 1px rgb(0, 0, 0),
|
||||||
inset 0 0 1px rgb(0, 0, 0);
|
inset 0 0 1px rgb(0, 0, 0);
|
||||||
}
|
}
|
||||||
.OxThemeClassic .OxCalendar .OxLine > .OxEvent.OxDate {
|
.OxThemeClassic .OxEvent.OxDate {
|
||||||
background: -moz-linear-gradient(top, rgba(128, 128, 255, 0.9), rgba(96, 96, 224, 0.9));
|
background: -moz-linear-gradient(top, rgba(128, 128, 255, 0.9), rgba(96, 96, 224, 0.9));
|
||||||
background: -o-linear-gradient(top, rgba(128, 128, 255, 0.9), rgba(96, 96, 224, 0.9));
|
background: -o-linear-gradient(top, rgba(128, 128, 255, 0.9), rgba(96, 96, 224, 0.9));
|
||||||
background: -webkit-linear-gradient(top, rgba(128, 128, 255, 0.9), rgba(96, 96, 224, 0.9));
|
background: -webkit-linear-gradient(top, rgba(128, 128, 255, 0.9), rgba(96, 96, 224, 0.9));
|
||||||
}
|
}
|
||||||
.OxThemeClassic .OxCalendar .OxLine > .OxEvent.OxPlace {
|
.OxThemeClassic .OxEvent.OxPlace {
|
||||||
background: -moz-linear-gradient(top, rgba(0, 192, 96, 0.9), rgba(0, 160, 64, 0.9));
|
background: -moz-linear-gradient(top, rgba(0, 192, 96, 0.9), rgba(0, 160, 64, 0.9));
|
||||||
background: -o-linear-gradient(top, rgba(0, 192, 96, 0.9), rgba(0, 160, 64, 0.9));
|
background: -o-linear-gradient(top, rgba(0, 192, 96, 0.9), rgba(0, 160, 64, 0.9));
|
||||||
background: -webkit-linear-gradient(top, rgba(0, 192, 96, 0.9), rgba(0, 160, 64, 0.9));
|
background: -webkit-linear-gradient(top, rgba(0, 192, 96, 0.9), rgba(0, 160, 64, 0.9));
|
||||||
}
|
}
|
||||||
.OxThemeClassic .OxCalendar .OxLine > .OxEvent.OxPerson {
|
.OxThemeClassic .OxEvent.OxPerson {
|
||||||
background: -moz-linear-gradient(top, rgba(255, 128, 0, 0.9), rgba(224, 96, 0, 0.9));
|
background: -moz-linear-gradient(top, rgba(255, 128, 0, 0.9), rgba(224, 96, 0, 0.9));
|
||||||
background: -o-linear-gradient(top, rgba(255, 128, 0, 0.9), rgba(224, 96, 0, 0.9));
|
background: -o-linear-gradient(top, rgba(255, 128, 0, 0.9), rgba(224, 96, 0, 0.9));
|
||||||
background: -webkit-linear-gradient(top, rgba(255, 128, 0, 0.9), rgba(224, 96, 0, 0.9));
|
background: -webkit-linear-gradient(top, rgba(255, 128, 0, 0.9), rgba(224, 96, 0, 0.9));
|
||||||
}
|
}
|
||||||
.OxThemeClassic .OxCalendar .OxLine > .OxEvent.OxOther {
|
.OxThemeClassic .OxEvent.OxOther {
|
||||||
background: -moz-linear-gradient(top, rgba(255, 128, 128, 0.9), rgba(224, 96, 96, 0.9));
|
background: -moz-linear-gradient(top, rgba(255, 128, 128, 0.9), rgba(224, 96, 96, 0.9));
|
||||||
background: -o-linear-gradient(top, rgba(255, 128, 128, 0.9), rgba(224, 96, 96, 0.9));
|
background: -o-linear-gradient(top, rgba(255, 128, 128, 0.9), rgba(224, 96, 96, 0.9));
|
||||||
background: -webkit-linear-gradient(top, rgba(255, 64, 64, 0.9), rgba(224, 32, 32, 0.9));
|
background: -webkit-linear-gradient(top, rgba(255, 64, 64, 0.9), rgba(224, 32, 32, 0.9));
|
||||||
|
@ -177,6 +180,10 @@ Calendar
|
||||||
color: rgb(64, 64, 64);
|
color: rgb(64, 64, 64);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
.OxThemeClassic .OxListCalendar .OxWarning {
|
||||||
|
border-bottom: 2px dotted rgb(255, 64, 64);
|
||||||
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
================================================================================
|
================================================================================
|
||||||
Dialog
|
Dialog
|
||||||
|
|
|
@ -18,6 +18,9 @@ body.OxThemeModern {
|
||||||
.OxThemeModern .OxBright {
|
.OxThemeModern .OxBright {
|
||||||
color: rgb(255, 255, 255);
|
color: rgb(255, 255, 255);
|
||||||
}
|
}
|
||||||
|
.OxThemeModern .OxLight {
|
||||||
|
color: rgb(128, 128, 128);
|
||||||
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
================================================================================
|
================================================================================
|
||||||
|
@ -139,22 +142,22 @@ Calendar
|
||||||
inset 0 0 1px rgb(255, 255, 255),
|
inset 0 0 1px rgb(255, 255, 255),
|
||||||
inset 0 0 1px rgb(255, 255, 255);
|
inset 0 0 1px rgb(255, 255, 255);
|
||||||
}
|
}
|
||||||
.OxThemeModern .OxCalendar .OxLine > .OxEvent.OxDate {
|
.OxThemeModern .OxEvent.OxDate {
|
||||||
background: -moz-linear-gradient(top, rgba(96, 96, 192, 0.9), rgba(64, 64, 160, 0.9));
|
background: -moz-linear-gradient(top, rgba(96, 96, 192, 0.9), rgba(64, 64, 160, 0.9));
|
||||||
background: -o-linear-gradient(top, rgba(96, 96, 192, 0.9), rgba(64, 64, 160, 0.9));
|
background: -o-linear-gradient(top, rgba(96, 96, 192, 0.9), rgba(64, 64, 160, 0.9));
|
||||||
background: -webkit-linear-gradient(top, rgba(96, 96, 255, 0.9), rgba(64, 64, 224, 0.9));
|
background: -webkit-linear-gradient(top, rgba(96, 96, 255, 0.9), rgba(64, 64, 224, 0.9));
|
||||||
}
|
}
|
||||||
.OxThemeModern .OxCalendar .OxLine > .OxEvent.OxPlace {
|
.OxThemeModern .OxEvent.OxPlace {
|
||||||
background: -moz-linear-gradient(top, rgba(0, 128, 96, 0.9), rgba(0, 96, 64, 0.9));
|
background: -moz-linear-gradient(top, rgba(0, 128, 96, 0.9), rgba(0, 96, 64, 0.9));
|
||||||
background: -o-linear-gradient(top, rgba(0, 128, 96, 0.9), rgba(0, 96, 64, 0.9));
|
background: -o-linear-gradient(top, rgba(0, 128, 96, 0.9), rgba(0, 96, 64, 0.9));
|
||||||
background: -webkit-linear-gradient(top, rgba(0, 128, 96, 0.9), rgba(0, 96, 64, 0.9));
|
background: -webkit-linear-gradient(top, rgba(0, 128, 96, 0.9), rgba(0, 96, 64, 0.9));
|
||||||
}
|
}
|
||||||
.OxThemeModern .OxCalendar .OxLine > .OxEvent.OxPerson {
|
.OxThemeModern .OxEvent.OxPerson {
|
||||||
background: -moz-linear-gradient(top, rgba(255, 96, 0, 0.9), rgba(224, 64, 0, 0.9));
|
background: -moz-linear-gradient(top, rgba(255, 96, 0, 0.9), rgba(224, 64, 0, 0.9));
|
||||||
background: -o-linear-gradient(top, rgba(255, 96, 0, 0.9), rgba(224, 64, 0, 0.9));
|
background: -o-linear-gradient(top, rgba(255, 96, 0, 0.9), rgba(224, 64, 0, 0.9));
|
||||||
background: -webkit-linear-gradient(top, rgba(255, 96, 0, 0.9), rgba(224, 64, 0, 0.9));
|
background: -webkit-linear-gradient(top, rgba(255, 96, 0, 0.9), rgba(224, 64, 0, 0.9));
|
||||||
}
|
}
|
||||||
.OxThemeModern .OxCalendar .OxLine > .OxEvent.OxOther {
|
.OxThemeModern .OxEvent.OxOther {
|
||||||
background: -moz-linear-gradient(top, rgba(192, 32, 32, 0.9), rgba(160, 0, 0, 0.9));
|
background: -moz-linear-gradient(top, rgba(192, 32, 32, 0.9), rgba(160, 0, 0, 0.9));
|
||||||
background: -o-linear-gradient(top, rgba(192, 32, 32, 0.9), rgba(160, 0, 0, 0.9));
|
background: -o-linear-gradient(top, rgba(192, 32, 32, 0.9), rgba(160, 0, 0, 0.9));
|
||||||
background: -webkit-linear-gradient(top, rgba(192, 32, 32, 0.9), rgba(160, 0, 0, 0.9));
|
background: -webkit-linear-gradient(top, rgba(192, 32, 32, 0.9), rgba(160, 0, 0, 0.9));
|
||||||
|
@ -176,6 +179,10 @@ Calendar
|
||||||
color: rgb(192, 192, 192);
|
color: rgb(192, 192, 192);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
.OxThemeModern .OxListCalendar .OxWarning {
|
||||||
|
border-bottom: 2px dotted rgb(192, 0, 0);
|
||||||
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
================================================================================
|
================================================================================
|
||||||
Dialog
|
Dialog
|
||||||
|
|
Loading…
Reference in a new issue