Merge branch 'dev' of https://framagit.org/hubzilla/core into dev
This commit is contained in:
		
							
								
								
									
										56
									
								
								CHANGELOG
									
									
									
									
									
								
							
							
						
						
									
										56
									
								
								CHANGELOG
									
									
									
									
									
								
							| @@ -1,3 +1,59 @@ | |||||||
|  | Hubzilla 4.2 (2019-??-??) | ||||||
|  | 	- Introduce Calendar app which deprecates Events and CalDAV apps and streamlines the featuresets | ||||||
|  | 	- Update mod cal to reflect changes in the calendar app | ||||||
|  | 	- Improve timezone detection for CalDAV calendars | ||||||
|  | 	- Add mention support to event description in channel calendar | ||||||
|  | 	- Update jgrowl library | ||||||
|  | 	- Do not try to oembed URLs without embed tags | ||||||
|  | 	- Optimise pdf oembed processing | ||||||
|  | 	- Add form security token to mod register | ||||||
|  | 	- Replace photo URL for gallery on clonned channel post sync | ||||||
|  | 	- Update justified gallery library | ||||||
|  | 	- Update bootstrap libraries | ||||||
|  | 	- Use "cache" flag for bbcode() on content destined for zot6 | ||||||
|  | 	- Improve DB indexing | ||||||
|  | 	- Drop deprecated columns from channel the table | ||||||
|  | 	- Replace own image URL in clonned channel posts | ||||||
|  | 	- Improve DB update handling | ||||||
|  | 	- Improve item deletion when a contact was removed | ||||||
|  | 	- Zot6 compatibility for emoji reactions | ||||||
|  | 	- Add threaded comments support (disabled by default) | ||||||
|  | 	- Improve xmlify()/unxmlify() performance | ||||||
|  | 	- Update blueimp/jquery-file-uplad library | ||||||
|  | 	- Update sabre/vobject library | ||||||
|  | 	- Various doco updates | ||||||
|  | 	- Implement remove profile photo button (reset to default photo) | ||||||
|  | 	- Implement remove cover photo button | ||||||
|  | 	- Update the homeinstall script | ||||||
|  | 	- Add command line tool for photo thumbnails storage conversion | ||||||
|  | 	- Implement option to store photo thumbnails in filesystem instead of DB | ||||||
|  |  | ||||||
|  | 	Bugfixes | ||||||
|  | 	- Fix encoded URLs in code blocks | ||||||
|  | 	- Fix wiki headers not escaped | ||||||
|  | 	- Fix possible xchan protocol confusion in new_contact() | ||||||
|  | 	- Fix xchan_url not displayed if xchan_addr not available | ||||||
|  | 	- Fix suggestion ordering in mod directory | ||||||
|  | 	- Fix event attachment delivery to zot6 | ||||||
|  |  | ||||||
|  | 	Addons | ||||||
|  | 	- pubcrawl: improve friendica compatibility by adding the nonstandard diaspora:guid field | ||||||
|  | 	- pubcrawl: initial suport for events | ||||||
|  | 	- pubcrawl: improve permalink detection | ||||||
|  | 	- flashcards: fix moving learn buttons if viewport sizes changes | ||||||
|  | 	- flashcards: Move card details to the bottom of a card | ||||||
|  | 	- upgrade_info: provide links to changelog | ||||||
|  | 	- photocache: do not save filename for cached photos | ||||||
|  | 	- pubcrawl: save local comment activitypub payload in iconfig to be used for relay | ||||||
|  | 	- flashcards: UI improvements in box settings | ||||||
|  | 	- pubcrawl: implement profile update messages | ||||||
|  | 	- pubcrawl: use URI instead of object for actor | ||||||
|  | 	- flashcards: fix jumping sync button | ||||||
|  | 	- pubcrawl: add threaded comments support | ||||||
|  | 	- pubcrawl: ignore target encoding errors | ||||||
|  | 	- pubcrawl: format photo items for activitypub | ||||||
|  |  | ||||||
|  |  | ||||||
| Hubzilla 4.0.3 (2019-04-26) | Hubzilla 4.0.3 (2019-04-26) | ||||||
| 	- Add attachments to zot6 event objects | 	- Add attachments to zot6 event objects | ||||||
| 	- Add zot6 to federated transports  | 	- Add zot6 to federated transports  | ||||||
|   | |||||||
| @@ -2766,7 +2766,7 @@ class Libzot { | |||||||
|  |  | ||||||
| 			$profile['description']   = $p[0]['pdesc']; | 			$profile['description']   = $p[0]['pdesc']; | ||||||
| 			$profile['birthday']      = $p[0]['dob']; | 			$profile['birthday']      = $p[0]['dob']; | ||||||
| 			if(($profile['birthday'] != '0000-00-00') && (($bd = z_birthday($p[0]['dob'],$e['channel_timezone'])) !== '')) | 			if(($profile['birthday'] != '0000-00-00') && (($bd = z_birthday($p[0]['dob'],'UTC')) !== '')) | ||||||
| 				$profile['next_birthday'] = $bd; | 				$profile['next_birthday'] = $bd; | ||||||
|  |  | ||||||
| 			if($age = age($p[0]['dob'],$e['channel_timezone'],'')) | 			if($age = age($p[0]['dob'],$e['channel_timezone'],'')) | ||||||
|   | |||||||
| @@ -84,6 +84,7 @@ class Cal extends \Zotlabs\Web\Controller { | |||||||
| 			'$module_url' => '/cal/' . $channel['channel_address'], | 			'$module_url' => '/cal/' . $channel['channel_address'], | ||||||
| 			'$modparams' => 2, | 			'$modparams' => 2, | ||||||
| 			'$lang' => \App::$language, | 			'$lang' => \App::$language, | ||||||
|  | 			'$timezone' => date_default_timezone_get(), | ||||||
| 			'$first_day' => $first_day | 			'$first_day' => $first_day | ||||||
| 		)); | 		)); | ||||||
| 	 | 	 | ||||||
| @@ -215,7 +216,7 @@ class Cal extends \Zotlabs\Web\Controller { | |||||||
| 				$sql_extra .= " and etype != 'birthday' "; | 				$sql_extra .= " and etype != 'birthday' "; | ||||||
|  |  | ||||||
| 			if (x($_GET,'id')){ | 			if (x($_GET,'id')){ | ||||||
| 			  	$r = q("SELECT event.*, item.plink, item.item_flags, item.author_xchan, item.owner_xchan | 				$r = q("SELECT event.*, item.plink, item.item_flags, item.author_xchan, item.owner_xchan, item.id as item_id | ||||||
| 					from event left join item on resource_id = event_hash where resource_type = 'event' and event.uid = %d and event.id = %d $sql_extra limit 1", | 					from event left join item on resource_id = event_hash where resource_type = 'event' and event.uid = %d and event.id = %d $sql_extra limit 1", | ||||||
| 					intval($channel['channel_id']), | 					intval($channel['channel_id']), | ||||||
| 					intval($_GET['id']) | 					intval($_GET['id']) | ||||||
| @@ -227,12 +228,12 @@ class Cal extends \Zotlabs\Web\Controller { | |||||||
| 				// Noting this for now - it will need to be fixed here and in Friendica. | 				// Noting this for now - it will need to be fixed here and in Friendica. | ||||||
| 				// Ultimately the finish date shouldn't be involved in the query.  | 				// Ultimately the finish date shouldn't be involved in the query.  | ||||||
| 	 | 	 | ||||||
| 				$r = q("SELECT event.*, item.plink, item.item_flags, item.author_xchan, item.owner_xchan | 				$r = q("SELECT event.*, item.plink, item.item_flags, item.author_xchan, item.owner_xchan, item.id as item_id | ||||||
| 	                              from event left join item on event_hash = resource_id  | 					from event left join item on event.event_hash = item.resource_id  | ||||||
| 					where resource_type = 'event' and event.uid = %d and event.uid = item.uid $ignored  | 					where item.resource_type = 'event' and event.uid = %d and event.uid = item.uid $ignored  | ||||||
| 					AND (( adjust = 0 AND ( dtend >= '%s' or nofinish = 1 ) AND dtstart <= '%s' )  | 					AND (( event.adjust = 0 AND ( event.dtend >= '%s' or event.nofinish = 1 ) AND event.dtstart <= '%s' )  | ||||||
| 					OR  (  adjust = 1 AND ( dtend >= '%s' or nofinish = 1 ) AND dtstart <= '%s' )) $sql_extra ", | 					OR  (  event.adjust = 1 AND ( event.dtend >= '%s' or event.nofinish = 1 ) AND event.dtstart <= '%s' )) ", | ||||||
| 					intval($channel['channel_id']), | 					intval(local_channel()), | ||||||
| 					dbesc($start), | 					dbesc($start), | ||||||
| 					dbesc($finish), | 					dbesc($finish), | ||||||
| 					dbesc($adjust_start), | 					dbesc($adjust_start), | ||||||
| @@ -267,15 +268,22 @@ class Cal extends \Zotlabs\Web\Controller { | |||||||
| 	 | 	 | ||||||
| 				foreach($r as $rr) { | 				foreach($r as $rr) { | ||||||
|  |  | ||||||
| 					$j = (($rr['adjust']) ? datetime_convert('UTC',date_default_timezone_get(),$rr['dtstart'], 'j') : datetime_convert('UTC','UTC',$rr['dtstart'],'j')); | 					$tz = get_iconfig($rr, 'event', 'timezone'); | ||||||
| 					$d = (($rr['adjust']) ? datetime_convert('UTC',date_default_timezone_get(),$rr['dtstart'], $fmt) : datetime_convert('UTC','UTC',$rr['dtstart'],$fmt)); |  | ||||||
|  | 					if(! $tz) | ||||||
|  | 						$tz = 'UTC'; | ||||||
|  |  | ||||||
|  | 					$rr['timezone'] = $tz; | ||||||
|  |  | ||||||
|  | 					$j = (($rr['adjust']) ? datetime_convert($tz,date_default_timezone_get(),$rr['dtstart'], 'j') : datetime_convert('UTC','UTC',$rr['dtstart'],'j')); | ||||||
|  | 					$d = (($rr['adjust']) ? datetime_convert($tz,date_default_timezone_get(),$rr['dtstart'], $fmt) : datetime_convert('UTC','UTC',$rr['dtstart'],$fmt)); | ||||||
| 					$d = day_translate($d); | 					$d = day_translate($d); | ||||||
| 					 | 					 | ||||||
| 					$start = (($rr['adjust']) ? datetime_convert('UTC',date_default_timezone_get(),$rr['dtstart'], 'c') : datetime_convert('UTC','UTC',$rr['dtstart'],'c')); | 					$start = (($rr['adjust']) ? datetime_convert($tz,date_default_timezone_get(),$rr['dtstart'], 'c') : datetime_convert('UTC','UTC',$rr['dtstart'],'c')); | ||||||
| 					if ($rr['nofinish']){ | 					if ($rr['nofinish']){ | ||||||
| 						$end = null; | 						$end = null; | ||||||
| 					} else { | 					} else { | ||||||
| 						$end = (($rr['adjust']) ? datetime_convert('UTC',date_default_timezone_get(),$rr['dtend'], 'c') : datetime_convert('UTC','UTC',$rr['dtend'],'c')); | 						$end = (($rr['adjust']) ? datetime_convert($tz,date_default_timezone_get(),$rr['dtend'], 'c') : datetime_convert('UTC','UTC',$rr['dtend'],'c')); | ||||||
| 					} | 					} | ||||||
| 					 | 					 | ||||||
| 					 | 					 | ||||||
| @@ -302,7 +310,7 @@ class Cal extends \Zotlabs\Web\Controller { | |||||||
| 						'start'=> $start, | 						'start'=> $start, | ||||||
| 						'end' => $end, | 						'end' => $end, | ||||||
| 						'drop' => $drop, | 						'drop' => $drop, | ||||||
| 						'allDay' => false, | 						'allDay' => (($rr['adjust']) ? 0 : 1), | ||||||
| 						'title' => $title, | 						'title' => $title, | ||||||
| 						 | 						 | ||||||
| 						'j' => $j, | 						'j' => $j, | ||||||
|   | |||||||
| @@ -271,11 +271,17 @@ class Cdav extends Controller { | |||||||
| 				if(!cdav_perms($id[0],$calendars,true)) | 				if(!cdav_perms($id[0],$calendars,true)) | ||||||
| 					return; | 					return; | ||||||
|  |  | ||||||
|  | 				$timezone = ((x($_POST,'timezone_select')) ? escape_tags(trim($_POST['timezone_select'])) : ''); | ||||||
|  | 				$tz = (($timezone) ? $timezone : date_default_timezone_get()); | ||||||
|  |  | ||||||
|  | 				$allday = $_REQUEST['allday']; | ||||||
|  |  | ||||||
| 				$title = $_REQUEST['title']; | 				$title = $_REQUEST['title']; | ||||||
| 				$start = datetime_convert(App::$timezone, 'UTC', $_REQUEST['dtstart']); | 				$start = datetime_convert($tz, 'UTC', $_REQUEST['dtstart']); | ||||||
| 				$dtstart = new \DateTime($start); | 				$dtstart = new \DateTime($start); | ||||||
|  |  | ||||||
| 				if($_REQUEST['dtend']) { | 				if($_REQUEST['dtend']) { | ||||||
| 					$end = datetime_convert(App::$timezone, 'UTC', $_REQUEST['dtend']); | 					$end = datetime_convert($tz, 'UTC', $_REQUEST['dtend']); | ||||||
| 					$dtend = new \DateTime($end); | 					$dtend = new \DateTime($end); | ||||||
| 				} | 				} | ||||||
| 				$description = $_REQUEST['description']; | 				$description = $_REQUEST['description']; | ||||||
| @@ -301,16 +307,23 @@ class Cdav extends Controller { | |||||||
| 					'DTSTART' => $dtstart | 					'DTSTART' => $dtstart | ||||||
| 				    ] | 				    ] | ||||||
| 				]); | 				]); | ||||||
|  |  | ||||||
| 				if($dtend) { | 				if($dtend) { | ||||||
| 					$vcalendar->VEVENT->add('DTEND', $dtend); | 					$vcalendar->VEVENT->add('DTEND', $dtend); | ||||||
| 					$vcalendar->VEVENT->DTEND['TZID'] = App::$timezone; | 					if($allday) | ||||||
|  | 						$vcalendar->VEVENT->DTEND['VALUE'] = 'DATE'; | ||||||
|  | 					else | ||||||
|  | 						$vcalendar->VEVENT->DTEND['TZID'] = $tz; | ||||||
| 				} | 				} | ||||||
| 				if($description) | 				if($description) | ||||||
| 					$vcalendar->VEVENT->add('DESCRIPTION', $description); | 					$vcalendar->VEVENT->add('DESCRIPTION', $description); | ||||||
| 				if($location) | 				if($location) | ||||||
| 					$vcalendar->VEVENT->add('LOCATION', $location); | 					$vcalendar->VEVENT->add('LOCATION', $location); | ||||||
|  |  | ||||||
| 				$vcalendar->VEVENT->DTSTART['TZID'] = App::$timezone; | 				if($allday) | ||||||
|  | 					$vcalendar->VEVENT->DTSTART['VALUE'] = 'DATE'; | ||||||
|  | 				else | ||||||
|  | 					$vcalendar->VEVENT->DTSTART['TZID'] = $tz; | ||||||
|  |  | ||||||
| 				$calendarData = $vcalendar->serialize(); | 				$calendarData = $vcalendar->serialize(); | ||||||
|  |  | ||||||
| @@ -348,12 +361,17 @@ class Cdav extends Controller { | |||||||
| 				if(!cdav_perms($id[0],$calendars,true)) | 				if(!cdav_perms($id[0],$calendars,true)) | ||||||
| 					return; | 					return; | ||||||
|  |  | ||||||
|  | 				$timezone = ((x($_POST,'timezone_select')) ? escape_tags(trim($_POST['timezone_select'])) : ''); | ||||||
|  | 				$tz = (($timezone) ? $timezone : date_default_timezone_get()); | ||||||
|  |  | ||||||
|  | 				$allday = $_REQUEST['allday']; | ||||||
|  |  | ||||||
| 				$uri = $_REQUEST['uri']; | 				$uri = $_REQUEST['uri']; | ||||||
| 				$title = $_REQUEST['title']; | 				$title = $_REQUEST['title']; | ||||||
| 				$start = datetime_convert(App::$timezone, 'UTC', $_REQUEST['dtstart']); | 				$start = datetime_convert($tz, 'UTC', $_REQUEST['dtstart']); | ||||||
| 				$dtstart = new \DateTime($start); | 				$dtstart = new \DateTime($start); | ||||||
| 				if($_REQUEST['dtend']) { | 				if($_REQUEST['dtend']) { | ||||||
| 					$end = datetime_convert(App::$timezone, 'UTC', $_REQUEST['dtend']); | 					$end = datetime_convert($tz, 'UTC', $_REQUEST['dtend']); | ||||||
| 					$dtend = new \DateTime($end); | 					$dtend = new \DateTime($end); | ||||||
| 				} | 				} | ||||||
| 				$description = $_REQUEST['description']; | 				$description = $_REQUEST['description']; | ||||||
| @@ -365,12 +383,23 @@ class Cdav extends Controller { | |||||||
|  |  | ||||||
| 				if($title) | 				if($title) | ||||||
| 					$vcalendar->VEVENT->SUMMARY = $title; | 					$vcalendar->VEVENT->SUMMARY = $title; | ||||||
| 				if($dtstart) | 				if($dtstart) { | ||||||
| 					$vcalendar->VEVENT->DTSTART = $dtstart; | 					$vcalendar->VEVENT->DTSTART = $dtstart; | ||||||
| 				if($dtend) | 					if($allday) | ||||||
|  | 						$vcalendar->VEVENT->DTSTART['VALUE'] = 'DATE'; | ||||||
|  | 					else | ||||||
|  | 						$vcalendar->VEVENT->DTSTART['TZID'] = $tz; | ||||||
|  | 				} | ||||||
|  | 				if($dtend) { | ||||||
| 					$vcalendar->VEVENT->DTEND = $dtend; | 					$vcalendar->VEVENT->DTEND = $dtend; | ||||||
|  | 					if($allday) | ||||||
|  | 						$vcalendar->VEVENT->DTEND['VALUE'] = 'DATE'; | ||||||
|  | 					else | ||||||
|  | 						$vcalendar->VEVENT->DTEND['TZID'] = $tz; | ||||||
|  | 				} | ||||||
| 				else | 				else | ||||||
| 					unset($vcalendar->VEVENT->DTEND); | 					unset($vcalendar->VEVENT->DTEND); | ||||||
|  |  | ||||||
| 				if($description) | 				if($description) | ||||||
| 					$vcalendar->VEVENT->DESCRIPTION = $description; | 					$vcalendar->VEVENT->DESCRIPTION = $description; | ||||||
| 				if($location) | 				if($location) | ||||||
| @@ -406,11 +435,16 @@ class Cdav extends Controller { | |||||||
| 				if(!cdav_perms($id[0],$calendars,true)) | 				if(!cdav_perms($id[0],$calendars,true)) | ||||||
| 					return; | 					return; | ||||||
|  |  | ||||||
|  | 				$timezone = ((x($_POST,'timezone_select')) ? escape_tags(trim($_POST['timezone_select'])) : ''); | ||||||
|  | 				$tz = (($timezone) ? $timezone : date_default_timezone_get()); | ||||||
|  |  | ||||||
|  | 				$allday = $_REQUEST['allday']; | ||||||
|  |  | ||||||
| 				$uri = $_REQUEST['uri']; | 				$uri = $_REQUEST['uri']; | ||||||
| 				$start = datetime_convert(App::$timezone, 'UTC', $_REQUEST['dtstart']); | 				$start = datetime_convert($tz, 'UTC', $_REQUEST['dtstart']); | ||||||
| 				$dtstart = new \DateTime($start); | 				$dtstart = new \DateTime($start); | ||||||
| 				if($_REQUEST['dtend']) { | 				if($_REQUEST['dtend']) { | ||||||
| 					$end = datetime_convert(App::$timezone, 'UTC', $_REQUEST['dtend']); | 					$end = datetime_convert($tz, 'UTC', $_REQUEST['dtend']); | ||||||
| 					$dtend = new \DateTime($end); | 					$dtend = new \DateTime($end); | ||||||
| 				} | 				} | ||||||
|  |  | ||||||
| @@ -420,13 +454,20 @@ class Cdav extends Controller { | |||||||
|  |  | ||||||
| 				if($dtstart) { | 				if($dtstart) { | ||||||
| 					$vcalendar->VEVENT->DTSTART = $dtstart; | 					$vcalendar->VEVENT->DTSTART = $dtstart; | ||||||
|  | 					if($allday) | ||||||
|  | 						$vcalendar->VEVENT->DTSTART['VALUE'] = 'DATE'; | ||||||
|  | 					else | ||||||
|  | 						$vcalendar->VEVENT->DTSTART['TZID'] = $tz; | ||||||
| 				} | 				} | ||||||
| 				if($dtend) { | 				if($dtend) { | ||||||
| 					$vcalendar->VEVENT->DTEND = $dtend; | 					$vcalendar->VEVENT->DTEND = $dtend; | ||||||
|  | 					if($allday) | ||||||
|  | 						$vcalendar->VEVENT->DTEND['VALUE'] = 'DATE'; | ||||||
|  | 					else | ||||||
|  | 						$vcalendar->VEVENT->DTEND['TZID'] = $tz; | ||||||
| 				} | 				} | ||||||
| 				else { | 				else | ||||||
| 					unset($vcalendar->VEVENT->DTEND); | 					unset($vcalendar->VEVENT->DTEND); | ||||||
| 				} |  | ||||||
|  |  | ||||||
| 				$calendarData = $vcalendar->serialize(); | 				$calendarData = $vcalendar->serialize(); | ||||||
|  |  | ||||||
| @@ -915,8 +956,13 @@ class Cdav extends Controller { | |||||||
| 					xchan_query($r); | 					xchan_query($r); | ||||||
| 					$r = fetch_post_tags($r,true); | 					$r = fetch_post_tags($r,true); | ||||||
|  |  | ||||||
| 					$r[0]['dtstart'] = (($r[0]['adjust']) ? datetime_convert('UTC',date_default_timezone_get(),$r[0]['dtstart'], 'c') : datetime_convert('UTC','UTC',$r[0]['dtstart'],'c')); | 					$tz = get_iconfig($r[0], 'event', 'timezone'); | ||||||
| 					$r[0]['dtend'] = (($r[0]['adjust']) ? datetime_convert('UTC',date_default_timezone_get(),$r[0]['dtend'], 'c') : datetime_convert('UTC','UTC',$r[0]['dtend'],'c')); | 					if(! $tz) | ||||||
|  | 						$tz = 'UTC'; | ||||||
|  |  | ||||||
|  | 					$r[0]['timezone'] = $tz; | ||||||
|  | 					$r[0]['dtstart'] = (($r[0]['adjust']) ? datetime_convert('UTC', date_default_timezone_get(), $r[0]['dtstart'], 'c') : datetime_convert('UTC', 'UTC', $r[0]['dtstart'], 'c')); | ||||||
|  | 					$r[0]['dtend'] = (($r[0]['adjust']) ? datetime_convert('UTC', date_default_timezone_get(), $r[0]['dtend'], 'c') : datetime_convert('UTC', 'UTC' ,$r[0]['dtend'], 'c')); | ||||||
|  |  | ||||||
| 					$r[0]['plink'] = [$r[0]['plink'], t('Link to source')]; | 					$r[0]['plink'] = [$r[0]['plink'], t('Link to source')]; | ||||||
|  |  | ||||||
| @@ -984,9 +1030,11 @@ class Cdav extends Controller { | |||||||
| 			$first_day = feature_enabled(local_channel(), 'cal_first_day'); | 			$first_day = feature_enabled(local_channel(), 'cal_first_day'); | ||||||
| 			$first_day = (($first_day) ? $first_day : 0); | 			$first_day = (($first_day) ? $first_day : 0); | ||||||
|  |  | ||||||
| 			$title = ['title', t('Event title')]; | 			$title = ['title', t('Event title') ]; | ||||||
| 			$dtstart = ['dtstart', t('Start date and time')]; | 			$dtstart = ['dtstart', t('Start date and time')]; | ||||||
| 			$dtend = ['dtend', t('End date and time')]; | 			$dtend = ['dtend', t('End date and time')]; | ||||||
|  | 			$timezone_select = ['timezone_select' , t('Timezone:'), date_default_timezone_get(), '', get_timezones()]; | ||||||
|  |  | ||||||
| 			$description = ['description', t('Description')]; | 			$description = ['description', t('Description')]; | ||||||
| 			$location = ['location', t('Location')]; | 			$location = ['location', t('Location')]; | ||||||
|  |  | ||||||
| @@ -1000,14 +1048,13 @@ class Cdav extends Controller { | |||||||
| 			//$acl = (($orig_event['event_xchan']) ? '' : populate_acl(((x($orig_event)) ? $orig_event : $perm_defaults), false, \Zotlabs\Lib\PermissionDescription::fromGlobalPermission('view_stream'))); | 			//$acl = (($orig_event['event_xchan']) ? '' : populate_acl(((x($orig_event)) ? $orig_event : $perm_defaults), false, \Zotlabs\Lib\PermissionDescription::fromGlobalPermission('view_stream'))); | ||||||
| 			$acl = populate_acl($perm_defaults, false, \Zotlabs\Lib\PermissionDescription::fromGlobalPermission('view_stream')); | 			$acl = populate_acl($perm_defaults, false, \Zotlabs\Lib\PermissionDescription::fromGlobalPermission('view_stream')); | ||||||
|  |  | ||||||
| 			//$permissions = ((x($orig_event)) ? $orig_event : $perm_defaults); | 			$permissions = (($resource_id) ? $resource : $perm_defaults); | ||||||
| 			$permissions = $perm_defaults; |  | ||||||
|  |  | ||||||
| 			$o .= replace_macros(get_markup_template('cdav_calendar.tpl'), [ | 			$o .= replace_macros(get_markup_template('cdav_calendar.tpl'), [ | ||||||
| 				'$sources' => $sources, | 				'$sources' => $sources, | ||||||
| 				'$color' => $color, | 				'$color' => $color, | ||||||
| 				'$lang' => App::$language, | 				'$lang' => App::$language, | ||||||
| 				'$timezone' => App::$timezone, | 				'$timezone' => date_default_timezone_get(), | ||||||
| 				'$first_day' => $first_day, | 				'$first_day' => $first_day, | ||||||
| 				'$prev'	=> t('Previous'), | 				'$prev'	=> t('Previous'), | ||||||
| 				'$next'	=> t('Next'), | 				'$next'	=> t('Next'), | ||||||
| @@ -1047,7 +1094,8 @@ class Cdav extends Controller { | |||||||
| 				'$categories_label' => t('Categories'), | 				'$categories_label' => t('Categories'), | ||||||
|  |  | ||||||
| 				'$resource' => json_encode($resource), | 				'$resource' => json_encode($resource), | ||||||
| 				'$categories' => $categories | 				'$categories' => $categories, | ||||||
|  | 				'$timezone_select' => ((feature_enabled(local_channel(),'event_tz_select')) ? $timezone_select : '') | ||||||
| 			]); | 			]); | ||||||
|  |  | ||||||
| 			return $o; | 			return $o; | ||||||
| @@ -1076,8 +1124,8 @@ class Cdav extends Controller { | |||||||
| 			$filters['comp-filters'][0]['time-range']['end'] = $end; | 			$filters['comp-filters'][0]['time-range']['end'] = $end; | ||||||
|  |  | ||||||
| 			$uris = $caldavBackend->calendarQuery($id, $filters); | 			$uris = $caldavBackend->calendarQuery($id, $filters); | ||||||
|  |  | ||||||
| 			if($uris) { | 			if($uris) { | ||||||
|  |  | ||||||
| 				$objects = $caldavBackend->getMultipleCalendarObjects($id, $uris); | 				$objects = $caldavBackend->getMultipleCalendarObjects($id, $uris); | ||||||
| 				foreach($objects as $object) { | 				foreach($objects as $object) { | ||||||
|  |  | ||||||
| @@ -1096,30 +1144,33 @@ class Cdav extends Controller { | |||||||
| 						$dtend = (string)$vevent->DTEND; | 						$dtend = (string)$vevent->DTEND; | ||||||
| 						$description = (string)$vevent->DESCRIPTION; | 						$description = (string)$vevent->DESCRIPTION; | ||||||
| 						$location = (string)$vevent->LOCATION; | 						$location = (string)$vevent->LOCATION; | ||||||
| 						$timezone = (string)$vevent->DTSTART['TZID']; | 						$timezone_str = (string)$vevent->DTSTART['TZID']; | ||||||
| 						$rw = ((cdav_perms($id[0],$calendars,true)) ? true : false); | 						$rw = ((cdav_perms($id[0],$calendars,true)) ? true : false); | ||||||
| 						$editable = $rw ? true : false; | 						$editable = $rw ? true : false; | ||||||
| 						$recurrent = ((isset($vevent->{'RECURRENCE-ID'})) ? true : false); | 						$recurrent = ((isset($vevent->{'RECURRENCE-ID'})) ? true : false); | ||||||
|  |  | ||||||
| 						if($recurrent) { | 						if($recurrent) { | ||||||
| 							$editable = false; | 							$editable = false; | ||||||
| 							$timezone = $recurrent_timezone; | 							$timezone_str = $recurrent_timezone; | ||||||
| 						} | 						} | ||||||
|  |  | ||||||
| 						$allDay = false; | 						// Try to get an usable olson format timezone | ||||||
|  | 						$timezone_obj = \Sabre\VObject\TimeZoneUtil::getTimeZone($timezone_str, $vcalendar); | ||||||
|  | 						$timezone = $timezone_obj->getName(); | ||||||
|  |  | ||||||
| 						// allDay event rules | 						// If we got nothing fallback to UTC | ||||||
| 						if(!strpos($dtstart, 'T') && !strpos($dtend, 'T')) | 						if(! $timezone) | ||||||
| 							$allDay = true; | 							$timezone = 'UTC'; | ||||||
| 						if(strpos($dtstart, 'T000000') && strpos($dtend, 'T000000')) |  | ||||||
| 							$allDay = true; | 						$allDay = (((string)$vevent->DTSTART['VALUE'] == 'DATE') ? true : false); | ||||||
|  |  | ||||||
| 						$events[] = [ | 						$events[] = [ | ||||||
| 							'calendar_id' => $id, | 							'calendar_id' => $id, | ||||||
| 							'uri' => $object['uri'], | 							'uri' => $object['uri'], | ||||||
| 							'title' => $title, | 							'title' => $title, | ||||||
| 							'start' => datetime_convert($timezone, $timezone, $dtstart, 'c'), | 							'timezone' => $timezone, | ||||||
| 							'end' => (($dtend) ? datetime_convert($timezone, $timezone, $dtend, 'c') : ''), | 							'start' => datetime_convert($timezone, date_default_timezone_get(), $dtstart, 'c'), | ||||||
|  | 							'end' => (($dtend) ? datetime_convert($timezone, date_default_timezone_get(), $dtend, 'c') : ''), | ||||||
| 							'description' => $description, | 							'description' => $description, | ||||||
| 							'location' => $location, | 							'location' => $location, | ||||||
| 							'allDay' => $allDay, | 							'allDay' => $allDay, | ||||||
|   | |||||||
| @@ -23,51 +23,19 @@ class Channel_calendar extends \Zotlabs\Web\Controller { | |||||||
| 		$xchan = ((x($_POST,'xchan')) ? dbesc($_POST['xchan']) : ''); | 		$xchan = ((x($_POST,'xchan')) ? dbesc($_POST['xchan']) : ''); | ||||||
| 		$uid      = local_channel(); | 		$uid      = local_channel(); | ||||||
|  |  | ||||||
| 		$start_text = escape_tags($_REQUEST['dtstart']); | 		// only allow editing your own events.  | ||||||
| 		$finish_text = escape_tags($_REQUEST['dtend']); | 		if(($xchan) && ($xchan !== get_observer_hash())) | ||||||
|  | 			return; | ||||||
| 		$adjust   = intval($_POST['adjust']); |  | ||||||
| 		$nofinish = intval($_POST['nofinish']); |  | ||||||
| 	 |  | ||||||
| 		$timezone = ((x($_POST,'timezone_select')) ? notags(trim($_POST['timezone_select']))     : ''); |  | ||||||
|  |  | ||||||
|  | 		$timezone = ((x($_POST,'timezone_select')) ? escape_tags(trim($_POST['timezone_select'])) : ''); | ||||||
| 		$tz = (($timezone) ? $timezone : date_default_timezone_get()); | 		$tz = (($timezone) ? $timezone : date_default_timezone_get()); | ||||||
|  |  | ||||||
| 		$categories = escape_tags(trim($_POST['categories'])); | 		$categories = escape_tags(trim($_POST['categories'])); | ||||||
| 		 | 		 | ||||||
| 		// only allow editing your own events.  | 		$adjust = intval($_POST['adjust']); | ||||||
|  |  | ||||||
| 		if(($xchan) && ($xchan !== get_observer_hash())) | 		$start = (($adjust) ? datetime_convert($tz, 'UTC', escape_tags($_REQUEST['dtstart'])) : datetime_convert('UTC', 'UTC', escape_tags($_REQUEST['dtstart']))); | ||||||
| 			return; | 		$finish = (($adjust) ? datetime_convert($tz, 'UTC', escape_tags($_REQUEST['dtend'])) : datetime_convert('UTC', 'UTC', escape_tags($_REQUEST['dtend']))); | ||||||
| 	 |  | ||||||
| 		if($start_text) { |  | ||||||
| 			$start = $start_text; |  | ||||||
| 		} |  | ||||||
| 		else { |  | ||||||
| 			$start = sprintf('%d-%d-%d %d:%d:0',$startyear,$startmonth,$startday,$starthour,$startminute); |  | ||||||
| 		} |  | ||||||
|  |  | ||||||
| 		if($finish_text) { |  | ||||||
| 			$finish = $finish_text; |  | ||||||
| 		} |  | ||||||
| 		else { |  | ||||||
| 			$finish = sprintf('%d-%d-%d %d:%d:0',$finishyear,$finishmonth,$finishday,$finishhour,$finishminute); |  | ||||||
| 		} |  | ||||||
|  |  | ||||||
| 		if($nofinish) { |  | ||||||
| 			$finish = NULL_DATE; |  | ||||||
| 		} |  | ||||||
|  |  | ||||||
| 		if($adjust) { |  | ||||||
| 			$start = datetime_convert($tz,'UTC',$start); |  | ||||||
| 			if(! $nofinish) |  | ||||||
| 				$finish = datetime_convert($tz,'UTC',$finish); |  | ||||||
| 		} |  | ||||||
| 		else { |  | ||||||
| 			$start = datetime_convert('UTC','UTC',$start); |  | ||||||
| 			if(! $nofinish) |  | ||||||
| 				$finish = datetime_convert('UTC','UTC',$finish); |  | ||||||
| 		} |  | ||||||
|  |  | ||||||
| 		$summary  = escape_tags(trim($_POST['summary'])); | 		$summary  = escape_tags(trim($_POST['summary'])); | ||||||
| 		$desc     = escape_tags(trim($_POST['desc'])); | 		$desc     = escape_tags(trim($_POST['desc'])); | ||||||
| @@ -176,7 +144,7 @@ class Channel_calendar extends \Zotlabs\Web\Controller { | |||||||
| 		$datarray['location'] = $location; | 		$datarray['location'] = $location; | ||||||
| 		$datarray['etype'] = $type; | 		$datarray['etype'] = $type; | ||||||
| 		$datarray['adjust'] = $adjust; | 		$datarray['adjust'] = $adjust; | ||||||
| 		$datarray['nofinish'] = $nofinish; | 		$datarray['nofinish'] = 0; | ||||||
| 		$datarray['uid'] = local_channel(); | 		$datarray['uid'] = local_channel(); | ||||||
| 		$datarray['account'] = get_account_id(); | 		$datarray['account'] = get_account_id(); | ||||||
| 		$datarray['event_xchan'] = $channel['channel_hash']; | 		$datarray['event_xchan'] = $channel['channel_hash']; | ||||||
| @@ -188,6 +156,8 @@ class Channel_calendar extends \Zotlabs\Web\Controller { | |||||||
| 		$datarray['id'] = $event_id; | 		$datarray['id'] = $event_id; | ||||||
| 		$datarray['created'] = $created; | 		$datarray['created'] = $created; | ||||||
| 		$datarray['edited'] = $edited; | 		$datarray['edited'] = $edited; | ||||||
|  | 		$datarray['timezone'] = $tz; | ||||||
|  |  | ||||||
| 	 | 	 | ||||||
| 		if(intval($_REQUEST['preview'])) { | 		if(intval($_REQUEST['preview'])) { | ||||||
| 			$html = format_event_html($datarray); | 			$html = format_event_html($datarray); | ||||||
| @@ -322,7 +292,6 @@ class Channel_calendar extends \Zotlabs\Web\Controller { | |||||||
| 	 | 	 | ||||||
| 			$start  = datetime_convert('UTC','UTC',$start); | 			$start  = datetime_convert('UTC','UTC',$start); | ||||||
| 			$finish = datetime_convert('UTC','UTC',$finish); | 			$finish = datetime_convert('UTC','UTC',$finish); | ||||||
| 	 |  | ||||||
| 			$adjust_start = datetime_convert('UTC', date_default_timezone_get(), $start); | 			$adjust_start = datetime_convert('UTC', date_default_timezone_get(), $start); | ||||||
| 			$adjust_finish = datetime_convert('UTC', date_default_timezone_get(), $finish); | 			$adjust_finish = datetime_convert('UTC', date_default_timezone_get(), $finish); | ||||||
|  |  | ||||||
| @@ -357,13 +326,11 @@ class Channel_calendar extends \Zotlabs\Web\Controller { | |||||||
| 					dbesc($adjust_start), | 					dbesc($adjust_start), | ||||||
| 					dbesc($adjust_finish) | 					dbesc($adjust_finish) | ||||||
| 				); | 				); | ||||||
|  |  | ||||||
| 			} | 			} | ||||||
| 	 | 	 | ||||||
| 			if($r && ! $export) { | 			if($r && ! $export) { | ||||||
| 				xchan_query($r); | 				xchan_query($r); | ||||||
| 				$r = fetch_post_tags($r,true); | 				$r = fetch_post_tags($r,true); | ||||||
|  |  | ||||||
| 				$r = sort_by_date($r); | 				$r = sort_by_date($r); | ||||||
| 			} | 			} | ||||||
|  |  | ||||||
| @@ -373,17 +340,16 @@ class Channel_calendar extends \Zotlabs\Web\Controller { | |||||||
| 	 | 	 | ||||||
| 				foreach($r as $rr) { | 				foreach($r as $rr) { | ||||||
|  |  | ||||||
| 					$start = (($rr['adjust']) ? datetime_convert('UTC',date_default_timezone_get(),$rr['dtstart'], 'c') : datetime_convert('UTC','UTC',$rr['dtstart'],'c')); | 					$tz = get_iconfig($rr, 'event', 'timezone'); | ||||||
|  |  | ||||||
|  | 					if(! $tz) | ||||||
|  | 						$tz = 'UTC'; | ||||||
|  |  | ||||||
|  | 					$start = (($rr['adjust']) ? datetime_convert($tz, date_default_timezone_get(), $rr['dtstart'], 'c') : datetime_convert('UTC', 'UTC', $rr['dtstart'], 'c')); | ||||||
| 					if ($rr['nofinish']){ | 					if ($rr['nofinish']){ | ||||||
| 						$end = null; | 						$end = null; | ||||||
| 					} else { | 					} else { | ||||||
| 						$end = (($rr['adjust']) ? datetime_convert('UTC',date_default_timezone_get(),$rr['dtend'], 'c') : datetime_convert('UTC','UTC',$rr['dtend'],'c')); | 						$end = (($rr['adjust']) ? datetime_convert($tz, date_default_timezone_get(), $rr['dtend'], 'c') : datetime_convert('UTC', 'UTC', $rr['dtend'], 'c')); | ||||||
|  |  | ||||||
| 						// give a fake end to birthdays so they get crammed into a  |  | ||||||
| 						// single day on the calendar |  | ||||||
|  |  | ||||||
| 						if($rr['etype'] === 'birthday') |  | ||||||
| 							$end = null; |  | ||||||
| 					} | 					} | ||||||
|  |  | ||||||
| 					$catsenabled = feature_enabled(local_channel(),'categories'); | 					$catsenabled = feature_enabled(local_channel(),'categories'); | ||||||
| @@ -399,14 +365,6 @@ class Channel_calendar extends \Zotlabs\Web\Controller { | |||||||
| 						} | 						} | ||||||
| 					} | 					} | ||||||
|  |  | ||||||
| 					$allDay = false; |  | ||||||
|  |  | ||||||
| 					// allDay event rules |  | ||||||
| 					if(!strpos($start, 'T') && !strpos($end, 'T')) |  | ||||||
| 						$allDay = true; |  | ||||||
| 					if(strpos($start, 'T00:00:00') && strpos($end, 'T00:00:00')) |  | ||||||
| 						$allDay = true; |  | ||||||
|  |  | ||||||
| 					$edit = ((local_channel() && $rr['author_xchan'] == get_observer_hash()) ? array(z_root().'/events/'.$rr['event_hash'].'?expandform=1',t('Edit event'),'','') : false); | 					$edit = ((local_channel() && $rr['author_xchan'] == get_observer_hash()) ? array(z_root().'/events/'.$rr['event_hash'].'?expandform=1',t('Edit event'),'','') : false); | ||||||
| 	 | 	 | ||||||
| 					$drop = array(z_root().'/events/drop/'.$rr['event_hash'],t('Delete event'),'',''); | 					$drop = array(z_root().'/events/drop/'.$rr['event_hash'],t('Delete event'),'',''); | ||||||
| @@ -416,13 +374,14 @@ class Channel_calendar extends \Zotlabs\Web\Controller { | |||||||
| 						'rw' => true, | 						'rw' => true, | ||||||
| 						'id'=>$rr['id'], | 						'id'=>$rr['id'], | ||||||
| 						'uri' => $rr['event_hash'], | 						'uri' => $rr['event_hash'], | ||||||
|  | 						'timezone' => $tz, | ||||||
| 						'start'=> $start, | 						'start'=> $start, | ||||||
| 						'end' => $end, | 						'end' => $end, | ||||||
| 						'drop' => $drop, | 						'drop' => $drop, | ||||||
| 						'allDay' => $allDay, | 						'allDay' => (($rr['adjust']) ? 0 : 1), | ||||||
| 						'title' => htmlentities($rr['summary'], ENT_COMPAT, 'UTF-8', false), | 						'title' => htmlentities($rr['summary'], ENT_COMPAT, 'UTF-8', false), | ||||||
| 						'editable' => $edit ? true : false, | 						'editable' => $edit ? true : false, | ||||||
| 						'item'=>$rr, | 						'item' => $rr, | ||||||
| 						'plink' => [$rr['plink'], t('Link to source')], | 						'plink' => [$rr['plink'], t('Link to source')], | ||||||
| 						'description' => htmlentities($rr['description'], ENT_COMPAT, 'UTF-8', false), | 						'description' => htmlentities($rr['description'], ENT_COMPAT, 'UTF-8', false), | ||||||
| 						'location' => htmlentities($rr['location'], ENT_COMPAT, 'UTF-8', false), | 						'location' => htmlentities($rr['location'], ENT_COMPAT, 'UTF-8', false), | ||||||
|   | |||||||
| @@ -293,9 +293,9 @@ class Wiki extends Controller { | |||||||
| 				} | 				} | ||||||
|  |  | ||||||
| 				//$wikiheaderName = urldecode($wikiUrlName); | 				//$wikiheaderName = urldecode($wikiUrlName); | ||||||
| 				$wikiheaderName = NativeWiki::name_decode($wikiUrlName); | 				$wikiheaderName = escape_tags(NativeWiki::name_decode($wikiUrlName)); | ||||||
| 				//$wikiheaderPage = urldecode($pageUrlName); | 				//$wikiheaderPage = urldecode($pageUrlName); | ||||||
| 				$wikiheaderPage = NativeWiki::name_decode($pageUrlName); | 				$wikiheaderPage = escape_tags(NativeWiki::name_decode($pageUrlName)); | ||||||
|  |  | ||||||
| 				$renamePage = (($wikiheaderPage === 'Home') ? '' : t('Rename page')); | 				$renamePage = (($wikiheaderPage === 'Home') ? '' : t('Rename page')); | ||||||
| 				$sharePage  = t('Share'); | 				$sharePage  = t('Share'); | ||||||
| @@ -373,13 +373,13 @@ class Wiki extends Controller { | |||||||
|  |  | ||||||
| 		$placeholder = t('Short description of your changes (optional)'); | 		$placeholder = t('Short description of your changes (optional)'); | ||||||
|  |  | ||||||
| 		$zrl = urlencode( z_root() . '/wiki/' . argv(1) . '/' . NativeWiki::name_encode($wikiUrlName) . '/' . NativeWiki::name_encode($pageUrlName) ); | 		$zrl = z_root() . '/wiki/' . argv(1) . '/' . NativeWiki::name_encode($wikiUrlName) . '/' . NativeWiki::name_encode($pageUrlName); | ||||||
| 		$o .= replace_macros(get_markup_template('wiki.tpl'),array( | 		$o .= replace_macros(get_markup_template('wiki.tpl'),array( | ||||||
| 			'$wikiheaderName' => $wikiheaderName, | 			'$wikiheaderName' => $wikiheaderName, | ||||||
| 			'$wikiheaderPage' => $wikiheaderPage, | 			'$wikiheaderPage' => $wikiheaderPage, | ||||||
| 			'$renamePage' => $renamePage, | 			'$renamePage' => $renamePage, | ||||||
| 			'$sharePage' => $sharePage, | 			'$sharePage' => $sharePage, | ||||||
| 			'$shareLink' => '#^[zrl=' . $zrl . ']' . '[ ' . $owner['channel_name'] . ' ] ' . $wikiheaderName . ' - ' . $wikiheaderPage . '[/zrl]', | 			'$shareLink' => urlencode('#^[zrl=' . $zrl . ']' . '[ ' . $owner['channel_name'] . ' ] ' . $wikiheaderName . ' - ' . $wikiheaderPage . '[/zrl]'), | ||||||
| 			'$showPageControls' => $showPageControls, | 			'$showPageControls' => $showPageControls, | ||||||
| 			'$editOrSourceLabel' => (($showPageControls) ? t('Edit') : t('Source')), | 			'$editOrSourceLabel' => (($showPageControls) ? t('Edit') : t('Source')), | ||||||
| 			'$tools_label' => 'Page Tools', | 			'$tools_label' => 'Page Tools', | ||||||
|   | |||||||
| @@ -509,7 +509,7 @@ abstract class PhotoDriver { | |||||||
| 	    $arr['imgscale'] = $scale; | 	    $arr['imgscale'] = $scale; | ||||||
|  |  | ||||||
| 		if(boolval(get_config('system','filesystem_storage_thumbnails', 0)) && $scale > 0) { | 		if(boolval(get_config('system','filesystem_storage_thumbnails', 0)) && $scale > 0) { | ||||||
| 			$channel = \App::get_channel(); | 			$channel = channelx_by_n($arr['uid']); | ||||||
| 			$arr['os_storage'] = 1; | 			$arr['os_storage'] = 1; | ||||||
| 			$arr['os_syspath'] = 'store/' . $channel['channel_address'] . '/' . $arr['os_path'] . '-' . $scale; | 			$arr['os_syspath'] = 'store/' . $channel['channel_address'] . '/' . $arr['os_path'] . '-' . $scale; | ||||||
| 			if(! $this->saveImage($arr['os_syspath'])) | 			if(! $this->saveImage($arr['os_syspath'])) | ||||||
|   | |||||||
| @@ -69,7 +69,7 @@ class Notifications { | |||||||
| 				'label' => t('New Events'), | 				'label' => t('New Events'), | ||||||
| 				'title' => t('New Events Notifications'), | 				'title' => t('New Events Notifications'), | ||||||
| 				'viewall' => [ | 				'viewall' => [ | ||||||
| 					'url' => 'events', | 					'url' => 'cdav/calendar', | ||||||
| 					'label' => t('View events') | 					'label' => t('View events') | ||||||
| 				], | 				], | ||||||
| 				'markall' => [ | 				'markall' => [ | ||||||
|   | |||||||
							
								
								
									
										3
									
								
								boot.php
									
									
									
									
									
								
							
							
						
						
									
										3
									
								
								boot.php
									
									
									
									
									
								
							| @@ -84,7 +84,8 @@ define ( 'DIRECTORY_FALLBACK_MASTER',  'https://zotadel.net'); | |||||||
|  |  | ||||||
| $DIRECTORY_FALLBACK_SERVERS = array( | $DIRECTORY_FALLBACK_SERVERS = array( | ||||||
| 	'https://zotadel.net', | 	'https://zotadel.net', | ||||||
| 	'https://zotsite.net' | 	'https://zotsite.net', | ||||||
|  | 	'https://hub.netzgemeinde.eu' | ||||||
| ); | ); | ||||||
|  |  | ||||||
|  |  | ||||||
|   | |||||||
| @@ -516,13 +516,14 @@ function update_birthdays() { | |||||||
| 				'event_xchan' => $rr['xchan_hash'], | 				'event_xchan' => $rr['xchan_hash'], | ||||||
| 				'dtstart'     => datetime_convert('UTC', 'UTC', $rr['abook_dob']), | 				'dtstart'     => datetime_convert('UTC', 'UTC', $rr['abook_dob']), | ||||||
| 				'dtend'       => datetime_convert('UTC', 'UTC', $rr['abook_dob'] . ' + 1 day '), | 				'dtend'       => datetime_convert('UTC', 'UTC', $rr['abook_dob'] . ' + 1 day '), | ||||||
| 				'adjust'      => intval(feature_enabled($rr['abook_channel'],'smart_birthdays')), | 				'adjust'      => 0, | ||||||
| 				'summary'     => sprintf( t('%1$s\'s birthday'), $rr['xchan_name']), | 				'summary'     => sprintf( t('%1$s\'s birthday'), $rr['xchan_name']), | ||||||
| 				'description' => sprintf( t('Happy Birthday %1$s'), '[zrl=' . $rr['xchan_url'] . ']' . $rr['xchan_name'] . '[/zrl]'), | 				'description' => sprintf( t('Happy Birthday %1$s'), '[zrl=' . $rr['xchan_url'] . ']' . $rr['xchan_name'] . '[/zrl]'), | ||||||
| 				'etype'       => 'birthday', | 				'etype'       => 'birthday', | ||||||
| 			]; | 			]; | ||||||
|  |  | ||||||
| 			$z = event_store_event($ev); | 			$z = event_store_event($ev); | ||||||
|  |  | ||||||
| 			if ($z) { | 			if ($z) { | ||||||
| 				$item_id = event_store_item($ev, $z); | 				$item_id = event_store_item($ev, $z); | ||||||
| 				q("update abook set abook_dob = '%s' where abook_id = %d", | 				q("update abook set abook_dob = '%s' where abook_id = %d", | ||||||
|   | |||||||
| @@ -27,6 +27,7 @@ function format_event_html($ev) { | |||||||
| 	if(! ((is_array($ev)) && count($ev))) | 	if(! ((is_array($ev)) && count($ev))) | ||||||
| 		return ''; | 		return ''; | ||||||
|  |  | ||||||
|  | 	$tz = (($ev['timezone']) ? $ev['timezone'] : 'UTC'); | ||||||
|  |  | ||||||
| 	$bd_format = t('l F d, Y \@ g:i A') ; // Friday January 18, 2011 @ 8:01 AM | 	$bd_format = t('l F d, Y \@ g:i A') ; // Friday January 18, 2011 @ 8:01 AM | ||||||
|  |  | ||||||
| @@ -39,7 +40,7 @@ function format_event_html($ev) { | |||||||
| 	$o .= '<div class="event-start"><span class="event-label">' . t('Starts:') . '</span> <span class="dtstart" title="' | 	$o .= '<div class="event-start"><span class="event-label">' . t('Starts:') . '</span> <span class="dtstart" title="' | ||||||
| 		. datetime_convert('UTC', 'UTC', $ev['dtstart'], (($ev['adjust']) ? ATOM_TIME : 'Y-m-d\TH:i:s' )) | 		. datetime_convert('UTC', 'UTC', $ev['dtstart'], (($ev['adjust']) ? ATOM_TIME : 'Y-m-d\TH:i:s' )) | ||||||
| 		. '" >' | 		. '" >' | ||||||
| 		. (($ev['adjust']) ? day_translate(datetime_convert('UTC', date_default_timezone_get(), | 		. (($ev['adjust']) ? day_translate(datetime_convert($tz, date_default_timezone_get(), | ||||||
| 			$ev['dtstart'] , $bd_format )) | 			$ev['dtstart'] , $bd_format )) | ||||||
| 			:  day_translate(datetime_convert('UTC', 'UTC', | 			:  day_translate(datetime_convert('UTC', 'UTC', | ||||||
| 			$ev['dtstart'] , $bd_format))) | 			$ev['dtstart'] , $bd_format))) | ||||||
| @@ -49,7 +50,7 @@ function format_event_html($ev) { | |||||||
| 		$o .= '<div class="event-end" ><span class="event-label">' . t('Finishes:') . '</span> <span class="dtend" title="' | 		$o .= '<div class="event-end" ><span class="event-label">' . t('Finishes:') . '</span> <span class="dtend" title="' | ||||||
| 			. datetime_convert('UTC','UTC',$ev['dtend'], (($ev['adjust']) ? ATOM_TIME : 'Y-m-d\TH:i:s' )) | 			. datetime_convert('UTC','UTC',$ev['dtend'], (($ev['adjust']) ? ATOM_TIME : 'Y-m-d\TH:i:s' )) | ||||||
| 			. '" >' | 			. '" >' | ||||||
| 			. (($ev['adjust']) ? day_translate(datetime_convert('UTC', date_default_timezone_get(), | 			. (($ev['adjust']) ? day_translate(datetime_convert($tz, date_default_timezone_get(), | ||||||
| 				$ev['dtend'] , $bd_format )) | 				$ev['dtend'] , $bd_format )) | ||||||
| 				:  day_translate(datetime_convert('UTC', 'UTC', | 				:  day_translate(datetime_convert('UTC', 'UTC', | ||||||
| 				$ev['dtend'] , $bd_format ))) | 				$ev['dtend'] , $bd_format ))) | ||||||
| @@ -75,17 +76,35 @@ function format_event_obj($jobject) { | |||||||
| 	//ensure compatibility with older items - this check can be removed at a later point | 	//ensure compatibility with older items - this check can be removed at a later point | ||||||
| 	if(array_key_exists('description', $object)) { | 	if(array_key_exists('description', $object)) { | ||||||
|  |  | ||||||
| 		$bd_format = t('l F d, Y \@ g:i A'); // Friday January 18, 2011 @ 8:01 AM | 		$tz = (($object['timezone']) ? $object['timezone'] : 'UTC'); | ||||||
|  | 		$allday = (($object['adjust']) ? false : true); | ||||||
|  |  | ||||||
|  | 		$dtstart = new DateTime($object['dtstart']); | ||||||
|  | 		$dtend = new DateTime($object['dtend']); | ||||||
|  | 		$dtdiff = $dtstart->diff($dtend); | ||||||
|  |  | ||||||
|  | 		if($allday && ($dtdiff->days < 2)) | ||||||
|  | 			$oneday = true; | ||||||
|  |  | ||||||
|  | 		if($allday && !$oneday) { | ||||||
|  | 			// Subtract one day from the end date so we can use the "first day - last day" format for display. | ||||||
|  | 			$dtend->modify('-1 day'); | ||||||
|  | 			$object['dtend'] = datetime_convert('UTC', 'UTC', $dtend->format('Y-m-d H:i:s')); | ||||||
|  | 		} | ||||||
|  |  | ||||||
|  | 		$bd_format = (($allday) ? t('l F d, Y') : t('l F d, Y \@ g:i A')); // Friday January 18, 2011 @ 8:01 AM or Friday January 18, 2011 for allday events | ||||||
|  |  | ||||||
| 		$event['header'] = replace_macros(get_markup_template('event_item_header.tpl'),array( | 		$event['header'] = replace_macros(get_markup_template('event_item_header.tpl'),array( | ||||||
| 			'$title'	 => zidify_links(smilies(bbcode($object['title']))), | 			'$title'	 => zidify_links(smilies(bbcode($object['title']))), | ||||||
| 			'$dtstart_label' => t('Starts:'), | 			'$dtstart_label' => t('Start:'), | ||||||
| 			'$dtstart_title' => datetime_convert('UTC', 'UTC', $object['dtstart'], (($object['adjust']) ? ATOM_TIME : 'Y-m-d\TH:i:s' )), | 			'$dtstart_title' => datetime_convert($tz, date_default_timezone_get(), $object['dtstart'], (($object['adjust']) ? ATOM_TIME : 'Y-m-d\TH:i:s' )), | ||||||
| 			'$dtstart_dt'	 => (($object['adjust']) ? day_translate(datetime_convert('UTC', date_default_timezone_get(), $object['dtstart'] , $bd_format )) : day_translate(datetime_convert('UTC', 'UTC', $object['dtstart'] , $bd_format))), | 			'$dtstart_dt'	 => (($object['adjust']) ? day_translate(datetime_convert($tz, date_default_timezone_get(), $object['dtstart'] , $bd_format )) : day_translate(datetime_convert('UTC', 'UTC', $object['dtstart'] , $bd_format))), | ||||||
| 			'$finish'	 => (($object['nofinish']) ? false : true), | 			'$finish'	 => (($object['nofinish']) ? false : true), | ||||||
| 			'$dtend_label'	 => t('Finishes:'), | 			'$dtend_label'	 => t('End:'), | ||||||
| 			'$dtend_title'	 => datetime_convert('UTC','UTC',$object['dtend'], (($object['adjust']) ? ATOM_TIME : 'Y-m-d\TH:i:s' )), | 			'$dtend_title'	 => datetime_convert($tz, date_default_timezone_get(), $object['dtend'], (($object['adjust']) ? ATOM_TIME : 'Y-m-d\TH:i:s' )), | ||||||
| 			'$dtend_dt'	 => (($object['adjust']) ? day_translate(datetime_convert('UTC', date_default_timezone_get(), $object['dtend'] , $bd_format )) :  day_translate(datetime_convert('UTC', 'UTC', $object['dtend'] , $bd_format ))) | 			'$dtend_dt'	 => (($object['adjust']) ? day_translate(datetime_convert($tz, date_default_timezone_get(), $object['dtend'] , $bd_format )) :  day_translate(datetime_convert('UTC', 'UTC', $object['dtend'] , $bd_format ))), | ||||||
|  | 			'$allday'	 => $allday, | ||||||
|  | 			'$oneday'	 => $oneday | ||||||
| 		)); | 		)); | ||||||
|  |  | ||||||
| 		$event['content'] = replace_macros(get_markup_template('event_item_content.tpl'),array( | 		$event['content'] = replace_macros(get_markup_template('event_item_content.tpl'),array( | ||||||
| @@ -1042,6 +1061,7 @@ function event_store_item($arr, $event) { | |||||||
| 			'type'    => ACTIVITY_OBJ_EVENT, | 			'type'    => ACTIVITY_OBJ_EVENT, | ||||||
| 			'id'      => z_root() . '/event/' . $r[0]['resource_id'], | 			'id'      => z_root() . '/event/' . $r[0]['resource_id'], | ||||||
| 			'title'   => $arr['summary'], | 			'title'   => $arr['summary'], | ||||||
|  | 			'timezone' => $arr['timezone'], | ||||||
| 			'dtstart' => $arr['dtstart'], | 			'dtstart' => $arr['dtstart'], | ||||||
| 			'dtend'  => $arr['dtend'], | 			'dtend'  => $arr['dtend'], | ||||||
| 			'nofinish'  => $arr['nofinish'], | 			'nofinish'  => $arr['nofinish'], | ||||||
| @@ -1107,6 +1127,8 @@ function event_store_item($arr, $event) { | |||||||
| 		} | 		} | ||||||
|  |  | ||||||
| 		$item_id = $r[0]['id']; | 		$item_id = $r[0]['id']; | ||||||
|  | 		set_iconfig($item_id, 'event', 'timezone', $arr['timezone'], true); | ||||||
|  |  | ||||||
| 		/** | 		/** | ||||||
| 		 * @hooks event_updated | 		 * @hooks event_updated | ||||||
| 		 *   Called when an event record is modified. | 		 *   Called when an event record is modified. | ||||||
| @@ -1197,6 +1219,7 @@ function event_store_item($arr, $event) { | |||||||
| 				'type'    => ACTIVITY_OBJ_EVENT, | 				'type'    => ACTIVITY_OBJ_EVENT, | ||||||
| 				'id'      => z_root() . '/event/' . $event['event_hash'], | 				'id'      => z_root() . '/event/' . $event['event_hash'], | ||||||
| 				'title'   => $arr['summary'], | 				'title'   => $arr['summary'], | ||||||
|  | 				'timezone' => $arr['timezone'], | ||||||
| 				'dtstart' => $arr['dtstart'], | 				'dtstart' => $arr['dtstart'], | ||||||
| 				'dtend'  => $arr['dtend'], | 				'dtend'  => $arr['dtend'], | ||||||
| 				'nofinish'  => $arr['nofinish'], | 				'nofinish'  => $arr['nofinish'], | ||||||
| @@ -1223,6 +1246,7 @@ function event_store_item($arr, $event) { | |||||||
| 		// activities refer to the item message_id as the parent.  | 		// activities refer to the item message_id as the parent.  | ||||||
|  |  | ||||||
| 		set_iconfig($item_arr, 'system','event_id',$event['event_hash'],true); | 		set_iconfig($item_arr, 'system','event_id',$event['event_hash'],true); | ||||||
|  | 		set_iconfig($item_arr, 'event','timezone',$arr['timezone'],true); | ||||||
|  |  | ||||||
| 		$res = item_store($item_arr); | 		$res = item_store($item_arr); | ||||||
|  |  | ||||||
|   | |||||||
| @@ -87,6 +87,14 @@ function get_features($filtered = true, $level = (-1)) { | |||||||
| 				t('Default is Sunday'), | 				t('Default is Sunday'), | ||||||
| 				false, | 				false, | ||||||
| 				get_config('feature_lock','cal_first_day') | 				get_config('feature_lock','cal_first_day') | ||||||
|  | 			], | ||||||
|  |  | ||||||
|  | 			[ | ||||||
|  | 				'event_tz_select', | ||||||
|  | 				t('Event Timezone Selection'), | ||||||
|  | 				t('Allow event creation in timezones other than your own.'), | ||||||
|  | 				false, | ||||||
|  | 				get_config('feature_lock','event_tz_select'), | ||||||
| 			] | 			] | ||||||
|  |  | ||||||
| 		], | 		], | ||||||
| @@ -282,22 +290,6 @@ function get_features($filtered = true, $level = (-1)) { | |||||||
| 				t('Default is Sunday'), | 				t('Default is Sunday'), | ||||||
| 				false, | 				false, | ||||||
| 				get_config('feature_lock','events_cal_first_day') | 				get_config('feature_lock','events_cal_first_day') | ||||||
| 			], |  | ||||||
|  |  | ||||||
| 			[ |  | ||||||
| 				'smart_birthdays', |  | ||||||
| 				t('Smart Birthdays'), |  | ||||||
| 				t('Make birthday events timezone aware in case your friends are scattered across the planet.'), |  | ||||||
| 				true, |  | ||||||
| 				get_config('feature_lock','smart_birthdays'), |  | ||||||
| 			], |  | ||||||
|  |  | ||||||
| 			[ |  | ||||||
| 				'event_tz_select', |  | ||||||
| 				t('Event Timezone Selection'), |  | ||||||
| 				t('Allow event creation in timezones other than your own.'), |  | ||||||
| 				false, |  | ||||||
| 				get_config('feature_lock','event_tz_select'), |  | ||||||
| 			] | 			] | ||||||
|  |  | ||||||
| 		], | 		], | ||||||
|   | |||||||
| @@ -219,8 +219,7 @@ function html2bbcode($message) | |||||||
|  |  | ||||||
| 	$message = $doc->saveHTML(); | 	$message = $doc->saveHTML(); | ||||||
|  |  | ||||||
| 	// I'm removing something really disturbing | 	// I'm removing the UTF-8 encoding of a NO-BREAK SPACE codepoint | ||||||
| 	// Don't know exactly what it is |  | ||||||
| 	$message = str_replace(chr(194).chr(160), ' ', $message); | 	$message = str_replace(chr(194).chr(160), ' ', $message); | ||||||
|  |  | ||||||
| 	$message = str_replace(" ", " ", $message); | 	$message = str_replace(" ", " ", $message); | ||||||
|   | |||||||
| @@ -76,6 +76,8 @@ function markdown_to_bb($s, $use_zrl = false, $options = []) { | |||||||
|  |  | ||||||
| 	$s = html2bbcode($s); | 	$s = html2bbcode($s); | ||||||
|  |  | ||||||
|  | 	$s = bb_code_protect($s); | ||||||
|  |  | ||||||
| 	// Convert everything that looks like a link to a link | 	// Convert everything that looks like a link to a link | ||||||
| 	if($use_zrl) { | 	if($use_zrl) { | ||||||
| 		if (strpos($s,'[/img]') !== false) { | 		if (strpos($s,'[/img]') !== false) { | ||||||
| @@ -88,6 +90,8 @@ function markdown_to_bb($s, $use_zrl = false, $options = []) { | |||||||
| 		$s = preg_replace("/([^\]\=\{\/]|^)(https?\:\/\/)([a-zA-Z0-9\pL\:\/\-\?\&\;\.\=\_\~\#\%\$\!\+\,\@\(\)]+)/ismu", '$1[url=$2$3]$2$3[/url]',$s); | 		$s = preg_replace("/([^\]\=\{\/]|^)(https?\:\/\/)([a-zA-Z0-9\pL\:\/\-\?\&\;\.\=\_\~\#\%\$\!\+\,\@\(\)]+)/ismu", '$1[url=$2$3]$2$3[/url]',$s); | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
|  | 	$s = bb_code_unprotect($s); | ||||||
|  |  | ||||||
| 	// remove duplicate adjacent code tags | 	// remove duplicate adjacent code tags | ||||||
| 	$s = preg_replace("/(\[code\])+(.*?)(\[\/code\])+/ism","[code]$2[/code]", $s); | 	$s = preg_replace("/(\[code\])+(.*?)(\[\/code\])+/ism","[code]$2[/code]", $s); | ||||||
|  |  | ||||||
|   | |||||||
| @@ -4430,7 +4430,7 @@ function zotinfo($arr) { | |||||||
|  |  | ||||||
| 		$profile['description']   = $p[0]['pdesc']; | 		$profile['description']   = $p[0]['pdesc']; | ||||||
| 		$profile['birthday']      = $p[0]['dob']; | 		$profile['birthday']      = $p[0]['dob']; | ||||||
| 		if(($profile['birthday'] != '0000-00-00') && (($bd = z_birthday($p[0]['dob'],$e['channel_timezone'])) !== '')) | 		if(($profile['birthday'] != '0000-00-00') && (($bd = z_birthday($p[0]['dob'],'UTC')) !== '')) | ||||||
| 			$profile['next_birthday'] = $bd; | 			$profile['next_birthday'] = $bd; | ||||||
|  |  | ||||||
| 		if($age = age($p[0]['dob'],$e['channel_timezone'],'')) | 		if($age = age($p[0]['dob'],$e['channel_timezone'],'')) | ||||||
|   | |||||||
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @@ -92,6 +92,8 @@ App::$strings["Profile"] = "Perfil"; | |||||||
| App::$strings["Click on a contact to add or remove."] = "Pulsar en un contacto para añadirlo o eliminarlo."; | App::$strings["Click on a contact to add or remove."] = "Pulsar en un contacto para añadirlo o eliminarlo."; | ||||||
| App::$strings["Visible To"] = "Visible para"; | App::$strings["Visible To"] = "Visible para"; | ||||||
| App::$strings["All Connections"] = "Todas las conexiones"; | App::$strings["All Connections"] = "Todas las conexiones"; | ||||||
|  | App::$strings["Calendar entries imported."] = "Entradas de calendario importadas."; | ||||||
|  | App::$strings["No calendar entries found."] = "No se han encontrado entradas de calendario."; | ||||||
| App::$strings["INVALID EVENT DISMISSED!"] = "¡EVENTO NO VÁLIDO RECHAZADO!"; | App::$strings["INVALID EVENT DISMISSED!"] = "¡EVENTO NO VÁLIDO RECHAZADO!"; | ||||||
| App::$strings["Summary: "] = "Resumen: "; | App::$strings["Summary: "] = "Resumen: "; | ||||||
| App::$strings["Unknown"] = "Desconocido"; | App::$strings["Unknown"] = "Desconocido"; | ||||||
| @@ -99,13 +101,11 @@ App::$strings["Date: "] = "Fecha: "; | |||||||
| App::$strings["Reason: "] = "Razón: "; | App::$strings["Reason: "] = "Razón: "; | ||||||
| App::$strings["INVALID CARD DISMISSED!"] = "¡TARJETA NO VÁLIDA RECHAZADA!"; | App::$strings["INVALID CARD DISMISSED!"] = "¡TARJETA NO VÁLIDA RECHAZADA!"; | ||||||
| App::$strings["Name: "] = "Nombre: "; | App::$strings["Name: "] = "Nombre: "; | ||||||
| App::$strings["CalDAV App"] = "App CalDav"; |  | ||||||
| App::$strings["CalDAV capable calendar"] = "Calendario compatible con CalDAV"; |  | ||||||
| App::$strings["CardDAV App"] = "App CarDav"; | App::$strings["CardDAV App"] = "App CarDav"; | ||||||
| App::$strings["CalDAV capable addressbook"] = "Libreta de direcciones compatible con CalDav"; | App::$strings["CalDAV capable addressbook"] = "Libreta de direcciones compatible con CalDav"; | ||||||
|  | App::$strings["Link to source"] = "Enlace a la fuente"; | ||||||
| App::$strings["Event title"] = "Título del evento"; | App::$strings["Event title"] = "Título del evento"; | ||||||
| App::$strings["Start date and time"] = "Fecha y hora de comienzo"; | App::$strings["Start date and time"] = "Fecha y hora de comienzo"; | ||||||
| App::$strings["Example: YYYY-MM-DD HH:mm"] = "Ejemplo: YYYY-MM-DD HH:mm"; |  | ||||||
| App::$strings["End date and time"] = "Fecha y hora de finalización"; | App::$strings["End date and time"] = "Fecha y hora de finalización"; | ||||||
| App::$strings["Description"] = "Descripción"; | App::$strings["Description"] = "Descripción"; | ||||||
| App::$strings["Location"] = "Ubicación"; | App::$strings["Location"] = "Ubicación"; | ||||||
| @@ -120,9 +120,13 @@ App::$strings["List week"] = "Lista semanal"; | |||||||
| App::$strings["List day"] = "Lista diaria"; | App::$strings["List day"] = "Lista diaria"; | ||||||
| App::$strings["More"] = "Más"; | App::$strings["More"] = "Más"; | ||||||
| App::$strings["Less"] = "Menos"; | App::$strings["Less"] = "Menos"; | ||||||
|  | App::$strings["Update"] = "Actualizar"; | ||||||
| App::$strings["Select calendar"] = "Seleccionar un calendario"; | App::$strings["Select calendar"] = "Seleccionar un calendario"; | ||||||
|  | App::$strings["Channel Calendars"] = "Calendarios del canal"; | ||||||
|  | App::$strings["CalDAV Calendars"] = "Calendarios CalDAV"; | ||||||
| App::$strings["Delete all"] = "Eliminar todos"; | App::$strings["Delete all"] = "Eliminar todos"; | ||||||
| App::$strings["Sorry! Editing of recurrent events is not yet implemented."] = "¡Disculpas! La edición de eventos recurrentes aún no se ha implementado."; | App::$strings["Sorry! Editing of recurrent events is not yet implemented."] = "¡Disculpas! La edición de eventos recurrentes aún no se ha implementado."; | ||||||
|  | App::$strings["Categories"] = "Temas"; | ||||||
| App::$strings["Name"] = "Nombre"; | App::$strings["Name"] = "Nombre"; | ||||||
| App::$strings["Organisation"] = "Organización"; | App::$strings["Organisation"] = "Organización"; | ||||||
| App::$strings["Title"] = "Título"; | App::$strings["Title"] = "Título"; | ||||||
| @@ -137,7 +141,6 @@ App::$strings["Home"] = "Inicio"; | |||||||
| App::$strings["Work"] = "Trabajo"; | App::$strings["Work"] = "Trabajo"; | ||||||
| App::$strings["Add Contact"] = "Añadir un contacto"; | App::$strings["Add Contact"] = "Añadir un contacto"; | ||||||
| App::$strings["Add Field"] = "Añadir un campo"; | App::$strings["Add Field"] = "Añadir un campo"; | ||||||
| App::$strings["Update"] = "Actualizar"; |  | ||||||
| App::$strings["P.O. Box"] = "Buzón de correos"; | App::$strings["P.O. Box"] = "Buzón de correos"; | ||||||
| App::$strings["Additional"] = "Adicional"; | App::$strings["Additional"] = "Adicional"; | ||||||
| App::$strings["Street"] = "Calle"; | App::$strings["Street"] = "Calle"; | ||||||
| @@ -237,8 +240,6 @@ App::$strings["Menu item deleted."] = "Este elemento del menú ha sido borrado"; | |||||||
| App::$strings["Menu item could not be deleted."] = "Este elemento del menú no puede ser borrado."; | App::$strings["Menu item could not be deleted."] = "Este elemento del menú no puede ser borrado."; | ||||||
| App::$strings["Edit Menu Element"] = "Editar elemento del menú"; | App::$strings["Edit Menu Element"] = "Editar elemento del menú"; | ||||||
| App::$strings["Link text"] = "Texto del enlace"; | App::$strings["Link text"] = "Texto del enlace"; | ||||||
| App::$strings["Calendar entries imported."] = "Entradas de calendario importadas."; |  | ||||||
| App::$strings["No calendar entries found."] = "No se han encontrado entradas de calendario."; |  | ||||||
| App::$strings["Event can not end before it has started."] = "Un evento no puede terminar antes de que haya comenzado."; | App::$strings["Event can not end before it has started."] = "Un evento no puede terminar antes de que haya comenzado."; | ||||||
| App::$strings["Unable to generate preview."] = "No se puede crear la vista previa."; | App::$strings["Unable to generate preview."] = "No se puede crear la vista previa."; | ||||||
| App::$strings["Event title and start time are required."] = "Se requieren el título del evento y su hora de inicio."; | App::$strings["Event title and start time are required."] = "Se requieren el título del evento y su hora de inicio."; | ||||||
| @@ -359,7 +360,7 @@ App::$strings["Website URL"] = "Dirección del sitio web"; | |||||||
| App::$strings["Please use SSL (https) URL if available."] = "Por favor, use SSL (https) si está disponible."; | App::$strings["Please use SSL (https) URL if available."] = "Por favor, use SSL (https) si está disponible."; | ||||||
| App::$strings["Please select a default timezone for your website"] = "Por favor, selecciones el huso horario por defecto de su sitio web"; | App::$strings["Please select a default timezone for your website"] = "Por favor, selecciones el huso horario por defecto de su sitio web"; | ||||||
| App::$strings["Site settings"] = "Ajustes del sitio"; | App::$strings["Site settings"] = "Ajustes del sitio"; | ||||||
| App::$strings["PHP version 5.5 or greater is required."] = "Se requiere la versión 5.5, o superior, de PHP."; | App::$strings["PHP version 7.1 or greater is required."] = "Se requiere la versión 7.1 o superior de PHP."; | ||||||
| App::$strings["PHP version"] = "Versión de PHP"; | App::$strings["PHP version"] = "Versión de PHP"; | ||||||
| App::$strings["Could not find a command line version of PHP in the web server PATH."] = "No se puede encontrar una versión en línea de comandos de PHP en la ruta del servidor web."; | App::$strings["Could not find a command line version of PHP in the web server PATH."] = "No se puede encontrar una versión en línea de comandos de PHP en la ruta del servidor web."; | ||||||
| App::$strings["If you don't have a command line version of PHP installed on server, you will not be able to run background polling via cron."] = "Si no tiene instalada la versión de línea de comandos de PHP en su servidor, no podrá realizar envíos en segundo plano mediante cron."; | App::$strings["If you don't have a command line version of PHP installed on server, you will not be able to run background polling via cron."] = "Si no tiene instalada la versión de línea de comandos de PHP en su servidor, no podrá realizar envíos en segundo plano mediante cron."; | ||||||
| @@ -446,12 +447,16 @@ App::$strings["On"] = "Activado"; | |||||||
| App::$strings["Lock feature %s"] = "Bloquear la funcionalidad %s"; | App::$strings["Lock feature %s"] = "Bloquear la funcionalidad %s"; | ||||||
| App::$strings["Manage Additional Features"] = "Gestionar las funcionalidades"; | App::$strings["Manage Additional Features"] = "Gestionar las funcionalidades"; | ||||||
| App::$strings["Update has been marked successful"] = "La actualización ha sido marcada como exitosa"; | App::$strings["Update has been marked successful"] = "La actualización ha sido marcada como exitosa"; | ||||||
| App::$strings["Executing %s failed. Check system logs."] = "La ejecución de %s ha fallado. Mirar en los informes del sistema."; | App::$strings["Verification of update %s failed. Check system logs."] = "Error en la verificación de la actualización %s. Compruebe los registros del sistema."; | ||||||
| App::$strings["Update %s was successfully applied."] = "La actualización de %s se ha realizado exitosamente."; | App::$strings["Update %s was successfully applied."] = "La actualización de %s se ha realizado exitosamente."; | ||||||
| App::$strings["Update %s did not return a status. Unknown if it succeeded."] = "La actualización de %s no ha devuelto ningún estado. No se sabe si ha tenido éxito."; | App::$strings["Verifying update %s did not return a status. Unknown if it succeeded."] = "La verificación de la actualización %s no devuelve un estado. Desconocido si tuvo éxito."; | ||||||
|  | App::$strings["Update %s does not contain a verification function."] = "La actualización %s no contiene una función de verificación."; | ||||||
| App::$strings["Update function %s could not be found."] = "No se encuentra la función de actualización de %s."; | App::$strings["Update function %s could not be found."] = "No se encuentra la función de actualización de %s."; | ||||||
|  | App::$strings["Executing update procedure %s failed. Check system logs."] = "Error al ejecutar el procedimiento de actualización %s. Compruebe los registros del sistema."; | ||||||
|  | App::$strings["Update %s did not return a status. It cannot be determined if it was successful."] = "La actualización %s no devuelve un estado. No se puede determinar si tuvo éxito."; | ||||||
| App::$strings["Failed Updates"] = "Han fallado las actualizaciones"; | App::$strings["Failed Updates"] = "Han fallado las actualizaciones"; | ||||||
| App::$strings["Mark success (if update was manually applied)"] = "Marcar como exitosa (si la actualización se ha hecho manualmente)"; | App::$strings["Mark success (if update was manually applied)"] = "Marcar como exitosa (si la actualización se ha hecho manualmente)"; | ||||||
|  | App::$strings["Attempt to verify this update if a verification procedure exists"] = "Intentar verificar esta actualización si existe un procedimiento de verificación."; | ||||||
| App::$strings["Attempt to execute this update step automatically"] = "Intentar ejecutar este paso de actualización automáticamente"; | App::$strings["Attempt to execute this update step automatically"] = "Intentar ejecutar este paso de actualización automáticamente"; | ||||||
| App::$strings["No failed updates."] = "No ha fallado ninguna actualización."; | App::$strings["No failed updates."] = "No ha fallado ninguna actualización."; | ||||||
| App::$strings["%s account blocked/unblocked"] = array( | App::$strings["%s account blocked/unblocked"] = array( | ||||||
| @@ -805,7 +810,7 @@ App::$strings["Default file upload folder"] = "Carpeta por defecto de los ficher | |||||||
| App::$strings["Remove this channel."] = "Eliminar este canal."; | App::$strings["Remove this channel."] = "Eliminar este canal."; | ||||||
| App::$strings["Additional Features"] = "Funcionalidades"; | App::$strings["Additional Features"] = "Funcionalidades"; | ||||||
| App::$strings["Events Settings"] = "Gestión de eventos"; | App::$strings["Events Settings"] = "Gestión de eventos"; | ||||||
| App::$strings["CalDAV Settings"] = "Ajustes de CalDav"; | App::$strings["Calendar Settings"] = "Ajustes del calendario"; | ||||||
| App::$strings["Settings saved."] = "Configuración guardada."; | App::$strings["Settings saved."] = "Configuración guardada."; | ||||||
| App::$strings["Settings saved. Reload page please."] = "Ajustes guardados. Recargue la página, por favor."; | App::$strings["Settings saved. Reload page please."] = "Ajustes guardados. Recargue la página, por favor."; | ||||||
| App::$strings["Conversation Settings"] = "Ajustes de conversación"; | App::$strings["Conversation Settings"] = "Ajustes de conversación"; | ||||||
| @@ -1685,8 +1690,8 @@ App::$strings["Invalid channel."] = "El canal no es válido."; | |||||||
| App::$strings["network"] = "red"; | App::$strings["network"] = "red"; | ||||||
| App::$strings["\$Projectname"] = "\$Projectname"; | App::$strings["\$Projectname"] = "\$Projectname"; | ||||||
| App::$strings["Welcome to %s"] = "Bienvenido a %s"; | App::$strings["Welcome to %s"] = "Bienvenido a %s"; | ||||||
| App::$strings["Permission Denied."] = "Permiso denegado"; |  | ||||||
| App::$strings["File not found."] = "Fichero no encontrado."; | App::$strings["File not found."] = "Fichero no encontrado."; | ||||||
|  | App::$strings["Permission Denied."] = "Permiso denegado"; | ||||||
| App::$strings["Edit file permissions"] = "Modificar los permisos del fichero"; | App::$strings["Edit file permissions"] = "Modificar los permisos del fichero"; | ||||||
| App::$strings["Set/edit permissions"] = "Establecer/editar los permisos"; | App::$strings["Set/edit permissions"] = "Establecer/editar los permisos"; | ||||||
| App::$strings["Include all files and sub folders"] = "Incluir todos los ficheros y subcarpetas"; | App::$strings["Include all files and sub folders"] = "Incluir todos los ficheros y subcarpetas"; | ||||||
| @@ -1766,13 +1771,15 @@ App::$strings["Site Admin"] = "Administrador del sitio"; | |||||||
| App::$strings["Report Bug"] = "Informe de errores"; | App::$strings["Report Bug"] = "Informe de errores"; | ||||||
| App::$strings["Bookmarks"] = "Marcadores"; | App::$strings["Bookmarks"] = "Marcadores"; | ||||||
| App::$strings["Chatrooms"] = "Salas de chat"; | App::$strings["Chatrooms"] = "Salas de chat"; | ||||||
|  | App::$strings["Content Filter"] = "Filtro de contenido"; | ||||||
|  | App::$strings["Content Import"] = "Importación de contenidos"; | ||||||
| App::$strings["Remote Diagnostics"] = "Diagnóstico remoto"; | App::$strings["Remote Diagnostics"] = "Diagnóstico remoto"; | ||||||
| App::$strings["Suggest Channels"] = "Sugerir canales"; | App::$strings["Suggest Channels"] = "Sugerir canales"; | ||||||
| App::$strings["Login"] = "Iniciar sesión"; | App::$strings["Login"] = "Iniciar sesión"; | ||||||
| App::$strings["Stream"] = "Stream"; | App::$strings["Stream"] = "Stream"; | ||||||
| App::$strings["Wiki"] = "Wiki"; | App::$strings["Wiki"] = "Wiki"; | ||||||
| App::$strings["Channel Home"] = "Mi canal"; | App::$strings["Channel Home"] = "Mi canal"; | ||||||
| App::$strings["Events"] = "Eventos"; | App::$strings["Calendar"] = "Calendario"; | ||||||
| App::$strings["Directory"] = "Directorio"; | App::$strings["Directory"] = "Directorio"; | ||||||
| App::$strings["Mail"] = "Correo"; | App::$strings["Mail"] = "Correo"; | ||||||
| App::$strings["Chat"] = "Chat"; | App::$strings["Chat"] = "Chat"; | ||||||
| @@ -1787,7 +1794,6 @@ App::$strings["Profile Photo"] = "Foto del perfil"; | |||||||
| App::$strings["Profiles"] = "Perfiles"; | App::$strings["Profiles"] = "Perfiles"; | ||||||
| App::$strings["Notifications"] = "Notificaciones"; | App::$strings["Notifications"] = "Notificaciones"; | ||||||
| App::$strings["Order Apps"] = "Ordenar las apps"; | App::$strings["Order Apps"] = "Ordenar las apps"; | ||||||
| App::$strings["CalDAV"] = "CalDAV"; |  | ||||||
| App::$strings["CardDAV"] = "CardDAV"; | App::$strings["CardDAV"] = "CardDAV"; | ||||||
| App::$strings["Guest Access"] = "Acceso para invitados"; | App::$strings["Guest Access"] = "Acceso para invitados"; | ||||||
| App::$strings["Notes"] = "Notas"; | App::$strings["Notes"] = "Notas"; | ||||||
| @@ -1912,6 +1918,7 @@ App::$strings["edited a post dated %s"] = "ha editado una entrada fechada el %s" | |||||||
| App::$strings["edited a comment dated %s"] = "ha editado un comentario fechado el %s"; | App::$strings["edited a comment dated %s"] = "ha editado un comentario fechado el %s"; | ||||||
| App::$strings["Wiki updated successfully"] = "El wiki se ha actualizado con éxito"; | App::$strings["Wiki updated successfully"] = "El wiki se ha actualizado con éxito"; | ||||||
| App::$strings["Wiki files deleted successfully"] = "Se han borrado con éxito los ficheros del wiki"; | App::$strings["Wiki files deleted successfully"] = "Se han borrado con éxito los ficheros del wiki"; | ||||||
|  | App::$strings["Source code of failed update: "] = "Código fuente de la actualización fallida: "; | ||||||
| App::$strings["Update Error at %s"] = "Error de actualización en %s"; | App::$strings["Update Error at %s"] = "Error de actualización en %s"; | ||||||
| App::$strings["Update %s failed. See error logs."] = "La actualización %s ha fallado. Mire el informe de errores."; | App::$strings["Update %s failed. See error logs."] = "La actualización %s ha fallado. Mire el informe de errores."; | ||||||
| App::$strings["Private Message"] = "Mensaje Privado"; | App::$strings["Private Message"] = "Mensaje Privado"; | ||||||
| @@ -1931,6 +1938,9 @@ App::$strings["Add Tag"] = "Añadir etiqueta"; | |||||||
| App::$strings["Conversation Tools"] = "Herramientas de conversación"; | App::$strings["Conversation Tools"] = "Herramientas de conversación"; | ||||||
| App::$strings["like"] = "me gusta"; | App::$strings["like"] = "me gusta"; | ||||||
| App::$strings["dislike"] = "no me gusta"; | App::$strings["dislike"] = "no me gusta"; | ||||||
|  | App::$strings["Reply on this comment"] = "Responder a este comentario"; | ||||||
|  | App::$strings["reply"] = "responder"; | ||||||
|  | App::$strings["Reply to"] = "Responder a "; | ||||||
| App::$strings["Share This"] = "Compartir esto"; | App::$strings["Share This"] = "Compartir esto"; | ||||||
| App::$strings["share"] = "compartir"; | App::$strings["share"] = "compartir"; | ||||||
| App::$strings["Delivery Report"] = "Informe de transmisión"; | App::$strings["Delivery Report"] = "Informe de transmisión"; | ||||||
| @@ -1950,6 +1960,7 @@ App::$strings["Attend"] = "Participar o asistir"; | |||||||
| App::$strings["Attendance Options"] = "Opciones de participación o asistencia"; | App::$strings["Attendance Options"] = "Opciones de participación o asistencia"; | ||||||
| App::$strings["Vote"] = "Votar"; | App::$strings["Vote"] = "Votar"; | ||||||
| App::$strings["Voting Options"] = "Opciones de votación"; | App::$strings["Voting Options"] = "Opciones de votación"; | ||||||
|  | App::$strings["Go to previous comment"] = "Ir al comentario anterior"; | ||||||
| App::$strings["Save Bookmarks"] = "Guardar en Marcadores"; | App::$strings["Save Bookmarks"] = "Guardar en Marcadores"; | ||||||
| App::$strings["Add to Calendar"] = "Añadir al calendario"; | App::$strings["Add to Calendar"] = "Añadir al calendario"; | ||||||
| App::$strings["This is an unsaved preview"] = "Esta es una previsualización sin guardar"; | App::$strings["This is an unsaved preview"] = "Esta es una previsualización sin guardar"; | ||||||
| @@ -1972,7 +1983,6 @@ App::$strings["parent"] = "padre"; | |||||||
| App::$strings["Collection"] = "Colección"; | App::$strings["Collection"] = "Colección"; | ||||||
| App::$strings["Principal"] = "Principal"; | App::$strings["Principal"] = "Principal"; | ||||||
| App::$strings["Addressbook"] = "Libreta de direcciones"; | App::$strings["Addressbook"] = "Libreta de direcciones"; | ||||||
| App::$strings["Calendar"] = "Calendario"; |  | ||||||
| App::$strings["Schedule Inbox"] = "Programar bandeja de entrada"; | App::$strings["Schedule Inbox"] = "Programar bandeja de entrada"; | ||||||
| App::$strings["Schedule Outbox"] = "Programar bandeja de salida"; | App::$strings["Schedule Outbox"] = "Programar bandeja de salida"; | ||||||
| App::$strings["Total"] = "Total"; | App::$strings["Total"] = "Total"; | ||||||
| @@ -1988,11 +1998,11 @@ App::$strings["Forums"] = "Foros"; | |||||||
| App::$strings["Select Channel"] = "Seleccionar un canal"; | App::$strings["Select Channel"] = "Seleccionar un canal"; | ||||||
| App::$strings["Read-write"] = "Lectura y escritura"; | App::$strings["Read-write"] = "Lectura y escritura"; | ||||||
| App::$strings["Read-only"] = "Sólo lectura"; | App::$strings["Read-only"] = "Sólo lectura"; | ||||||
| App::$strings["My Calendars"] = "Mis calendarios"; | App::$strings["Channel Calendar"] = "Calendario del canal"; | ||||||
| App::$strings["Shared Calendars"] = "Calendarios compartidos"; | App::$strings["Shared CalDAV Calendars"] = "Calendarios CalDAV compartidos"; | ||||||
| App::$strings["Share this calendar"] = "Compartir este calendario"; | App::$strings["Share this calendar"] = "Compartir este calendario"; | ||||||
| App::$strings["Calendar name and color"] = "Nombre y color del calendario"; | App::$strings["Calendar name and color"] = "Nombre y color del calendario"; | ||||||
| App::$strings["Create new calendar"] = "Crear un nuevo calendario"; | App::$strings["Create new CalDAV calendar"] = "Crear un nuevo calendario CalDAV"; | ||||||
| App::$strings["Calendar Name"] = "Nombre del calendario"; | App::$strings["Calendar Name"] = "Nombre del calendario"; | ||||||
| App::$strings["Calendar Tools"] = "Gestión de calendarios"; | App::$strings["Calendar Tools"] = "Gestión de calendarios"; | ||||||
| App::$strings["Import calendar"] = "Importar un calendario"; | App::$strings["Import calendar"] = "Importar un calendario"; | ||||||
| @@ -2004,7 +2014,6 @@ App::$strings["Addressbook Name"] = "Nombre de la agenda"; | |||||||
| App::$strings["Addressbook Tools"] = "Gestión de agendas de direcciones"; | App::$strings["Addressbook Tools"] = "Gestión de agendas de direcciones"; | ||||||
| App::$strings["Import addressbook"] = "Importar una agenda de direcciones"; | App::$strings["Import addressbook"] = "Importar una agenda de direcciones"; | ||||||
| App::$strings["Select an addressbook to import to"] = "Seleccionar una agenda para importarla"; | App::$strings["Select an addressbook to import to"] = "Seleccionar una agenda para importarla"; | ||||||
| App::$strings["Categories"] = "Temas"; |  | ||||||
| App::$strings["Everything"] = "Todo"; | App::$strings["Everything"] = "Todo"; | ||||||
| App::$strings["Events Tools"] = "Gestión de eventos"; | App::$strings["Events Tools"] = "Gestión de eventos"; | ||||||
| App::$strings["Export Calendar"] = "Exportar el calendario"; | App::$strings["Export Calendar"] = "Exportar el calendario"; | ||||||
| @@ -2507,11 +2516,11 @@ App::$strings["Approve subscription requests from Hubzilla contacts automaticall | |||||||
| App::$strings["Purge internal list of jabber addresses of contacts"] = "Purgar la lista interna de las direcciones de contactos de jabber"; | App::$strings["Purge internal list of jabber addresses of contacts"] = "Purgar la lista interna de las direcciones de contactos de jabber"; | ||||||
| App::$strings["Configuration Help"] = "Ayuda para los ajustes"; | App::$strings["Configuration Help"] = "Ayuda para los ajustes"; | ||||||
| App::$strings["Jappixmini Settings"] = "Ajustes de Jappixmini"; | App::$strings["Jappixmini Settings"] = "Ajustes de Jappixmini"; | ||||||
| App::$strings["Your channel has been upgraded to the latest \$Projectname version."] = "Su canal ha sido actualizado a la última versión de \$Projectname."; | App::$strings["Your channel has been upgraded to \$Projectname version"] = "Su canal ha sido actualizado a la versión \$Projectname"; | ||||||
| App::$strings["To improve usability, we have converted some features into installable stand-alone apps."] = "Para mejorar la usabilidad, hemos convertido algunas características en aplicaciones independientes instalables."; | App::$strings["Please have a look at the"] = "Por favor, eche un vistazo a la "; | ||||||
| App::$strings["Please visit the \$Projectname"] = "Por favor visite el sitio web de \$Projectname"; | App::$strings["git history"] = "historial del git"; | ||||||
| App::$strings["app store"] = "aplicaciones disponibles"; | App::$strings["change log"] = "lista de cambios"; | ||||||
| App::$strings["and install possibly missing apps."] = "e instale las aplicaciones que posiblemente falten."; | App::$strings["for further infos."] = "para más información."; | ||||||
| App::$strings["Upgrade Info"] = "Información de actualización"; | App::$strings["Upgrade Info"] = "Información de actualización"; | ||||||
| App::$strings["Do not show this again"] = "No mostrar esto de nuevo"; | App::$strings["Do not show this again"] = "No mostrar esto de nuevo"; | ||||||
| App::$strings["Access Denied"] = "Acceso denegado"; | App::$strings["Access Denied"] = "Acceso denegado"; | ||||||
| @@ -2527,8 +2536,11 @@ App::$strings["Reputation \"cost\" to comment"] = "\"Coste\" de la reputación p | |||||||
| App::$strings["Reputation automatically recovers at this rate per hour until it reaches minimum_to_post"] = "La reputación se recupera automáticamente a esta tasa por hora hasta que alcanza el mínimo_a_post"; | App::$strings["Reputation automatically recovers at this rate per hour until it reaches minimum_to_post"] = "La reputación se recupera automáticamente a esta tasa por hora hasta que alcanza el mínimo_a_post"; | ||||||
| App::$strings["When minimum_to_moderate > reputation > minimum_to_post reputation recovers at this rate per hour"] = "Cuando el mínimo_a_moderar > reputación > mínimo_a_publicar la reputación se recupera a esta tasa por hora "; | App::$strings["When minimum_to_moderate > reputation > minimum_to_post reputation recovers at this rate per hour"] = "Cuando el mínimo_a_moderar > reputación > mínimo_a_publicar la reputación se recupera a esta tasa por hora "; | ||||||
| App::$strings["Community Moderation Settings"] = "Configuración de la moderación de la comunidad"; | App::$strings["Community Moderation Settings"] = "Configuración de la moderación de la comunidad"; | ||||||
| App::$strings["Can moderate reputation on my channel."] = "Se puede moderar la reputación en mi canal."; |  | ||||||
| App::$strings["Channel Reputation"] = "Reputación del canal"; | App::$strings["Channel Reputation"] = "Reputación del canal"; | ||||||
|  | App::$strings["An Error has occurred."] = "Se ha producido un error."; | ||||||
|  | App::$strings["Upvote"] = "Votar a favor"; | ||||||
|  | App::$strings["Downvote"] = "Votar en contra"; | ||||||
|  | App::$strings["Can moderate reputation on my channel."] = "Se puede moderar la reputación en mi canal."; | ||||||
| App::$strings["Block Completely"] = "Bloquear completamente"; | App::$strings["Block Completely"] = "Bloquear completamente"; | ||||||
| App::$strings["Superblock App"] = "App Superblock"; | App::$strings["Superblock App"] = "App Superblock"; | ||||||
| App::$strings["Block channels"] = "Bloquear canales"; | App::$strings["Block channels"] = "Bloquear canales"; | ||||||
| @@ -2555,6 +2567,16 @@ App::$strings["Logfile archive directory"] = "Directorio de los ficheros de info | |||||||
| App::$strings["Directory to store rotated logs"] = "Directorio para almacenar los informes rotados"; | App::$strings["Directory to store rotated logs"] = "Directorio para almacenar los informes rotados"; | ||||||
| App::$strings["Logfile size in bytes before rotating"] = "Tamaño del fichero de informe en bytes antes de rotarlo"; | App::$strings["Logfile size in bytes before rotating"] = "Tamaño del fichero de informe en bytes antes de rotarlo"; | ||||||
| App::$strings["Number of logfiles to retain"] = "Número de ficheros de informe que se deben retener"; | App::$strings["Number of logfiles to retain"] = "Número de ficheros de informe que se deben retener"; | ||||||
|  | App::$strings["No server specified"] = "No se ha especificado ningún servidor"; | ||||||
|  | App::$strings["Posts imported"] = "Entradas importadas"; | ||||||
|  | App::$strings["Files imported"] = "Ficheros importados"; | ||||||
|  | App::$strings["This addon app copies existing content and file storage to a cloned/copied channel. Once the app is installed, visit the newly installed app. This will allow you to set the location of your original channel and an optional date range of files/conversations to copy."] = "Este complemento copia el contenido existente y el almacenamiento de ficheros en un canal clonado/copiado. Una vez instalada la aplicación, visite la aplicación recién instalada. Esto le permitirá establecer la ubicación de su canal original y un rango de fechas opcional de ficheros/conversaciones para copiar."; | ||||||
|  | App::$strings["This will import all your conversations and cloud files from a cloned channel on another server. This may take a while if you have lots of posts and or files."] = "Esto importará todas sus conversaciones y archivos de nube de un canal clonado en otro servidor. El proceso puede tardar un poco si tiene muchos mensajes y/o ficheros."; | ||||||
|  | App::$strings["Include posts"] = "Incluir entradas"; | ||||||
|  | App::$strings["Conversations, Articles, Cards, and other posted content"] = "Conversaciones, artículos, fichas y otros contenidos publicados"; | ||||||
|  | App::$strings["Include files"] = "Incluir ficheros"; | ||||||
|  | App::$strings["Files, Photos and other cloud storage"] = "Archivos, fotos y otro tipo de almacenamiento en la nube"; | ||||||
|  | App::$strings["Original Server base URL"] = "URL base del servidor original"; | ||||||
| App::$strings["Friendica Photo Album Import"] = "Importar un álbum de fotos de Friendica"; | App::$strings["Friendica Photo Album Import"] = "Importar un álbum de fotos de Friendica"; | ||||||
| App::$strings["This will import all your Friendica photo albums to this Red channel."] = "Esto importará todos sus álbumes de fotos de Friendica a este canal de Hubzilla."; | App::$strings["This will import all your Friendica photo albums to this Red channel."] = "Esto importará todos sus álbumes de fotos de Friendica a este canal de Hubzilla."; | ||||||
| App::$strings["Friendica Server base URL"] = "URL base del servidor de Friendica"; | App::$strings["Friendica Server base URL"] = "URL base del servidor de Friendica"; | ||||||
| @@ -3142,6 +3164,7 @@ App::$strings["Thank you, this nickname is valid."] = "Gracias, este alias es v | |||||||
| App::$strings["A channel name is required."] = "Se requiere un nombre de canal"; | App::$strings["A channel name is required."] = "Se requiere un nombre de canal"; | ||||||
| App::$strings["This is a "] = "Esto es un "; | App::$strings["This is a "] = "Esto es un "; | ||||||
| App::$strings[" channel name"] = "nombre de canal"; | App::$strings[" channel name"] = "nombre de canal"; | ||||||
|  | App::$strings["Back to reply"] = "Volver a la respuesta"; | ||||||
| App::$strings["%d minutes"] = array( | App::$strings["%d minutes"] = array( | ||||||
| 	0 => "%d minutos", | 	0 => "%d minutos", | ||||||
| 	1 => "%d minutos", | 	1 => "%d minutos", | ||||||
| @@ -3340,6 +3363,8 @@ App::$strings["Dislike Posts"] = "Desagrado de publicaciones"; | |||||||
| App::$strings["Ability to dislike posts/comments"] = "Capacidad de mostrar desacuerdo con el contenido de  entradas y comentarios"; | App::$strings["Ability to dislike posts/comments"] = "Capacidad de mostrar desacuerdo con el contenido de  entradas y comentarios"; | ||||||
| App::$strings["Star Posts"] = "Entradas destacadas"; | App::$strings["Star Posts"] = "Entradas destacadas"; | ||||||
| App::$strings["Ability to mark special posts with a star indicator"] = "Capacidad de marcar entradas destacadas con un indicador de estrella"; | App::$strings["Ability to mark special posts with a star indicator"] = "Capacidad de marcar entradas destacadas con un indicador de estrella"; | ||||||
|  | App::$strings["Reply on comment"] = "Responder a los comentarios"; | ||||||
|  | App::$strings["Ability to reply on selected comment"] = "Posibilidad de responder a los comentarios seleccionados"; | ||||||
| App::$strings["Advanced Directory Search"] = "Búsqueda avanzada en el directorio"; | App::$strings["Advanced Directory Search"] = "Búsqueda avanzada en el directorio"; | ||||||
| App::$strings["Allows creation of complex directory search queries"] = "Permitir la creación de consultas complejas en las búsquedas en el directorio"; | App::$strings["Allows creation of complex directory search queries"] = "Permitir la creación de consultas complejas en las búsquedas en el directorio"; | ||||||
| App::$strings["Editor"] = "Editor"; | App::$strings["Editor"] = "Editor"; | ||||||
| @@ -3361,6 +3386,7 @@ App::$strings["Suppress Duplicate Posts/Comments"] = "Prevenir entradas o coment | |||||||
| App::$strings["Prevent posts with identical content to be published with less than two minutes in between submissions."] = "Prevenir que entradas con contenido idéntico se publiquen con menos de dos minutos de intervalo."; | App::$strings["Prevent posts with identical content to be published with less than two minutes in between submissions."] = "Prevenir que entradas con contenido idéntico se publiquen con menos de dos minutos de intervalo."; | ||||||
| App::$strings["Auto-save drafts of posts and comments"] = "Guardar automáticamente borradores de entradas y comentarios"; | App::$strings["Auto-save drafts of posts and comments"] = "Guardar automáticamente borradores de entradas y comentarios"; | ||||||
| App::$strings["Automatically saves post and comment drafts in local browser storage to help prevent accidental loss of compositions"] = "Guarda automáticamente los borradores de comentarios y publicaciones en el almacenamiento del navegador local para ayudar a evitar la pérdida accidental de composiciones."; | App::$strings["Automatically saves post and comment drafts in local browser storage to help prevent accidental loss of compositions"] = "Guarda automáticamente los borradores de comentarios y publicaciones en el almacenamiento del navegador local para ayudar a evitar la pérdida accidental de composiciones."; | ||||||
|  | App::$strings["Events"] = "Eventos"; | ||||||
| App::$strings["Smart Birthdays"] = "Cumpleaños inteligentes"; | App::$strings["Smart Birthdays"] = "Cumpleaños inteligentes"; | ||||||
| App::$strings["Make birthday events timezone aware in case your friends are scattered across the planet."] = "Enlazar los eventos de cumpleaños con el huso horario en el caso de que sus amigos estén dispersos por el mundo."; | App::$strings["Make birthday events timezone aware in case your friends are scattered across the planet."] = "Enlazar los eventos de cumpleaños con el huso horario en el caso de que sus amigos estén dispersos por el mundo."; | ||||||
| App::$strings["Event Timezone Selection"] = "Selección del huso horario del evento"; | App::$strings["Event Timezone Selection"] = "Selección del huso horario del evento"; | ||||||
| @@ -3378,7 +3404,6 @@ App::$strings["Forum Filter"] = "Filtro de foro"; | |||||||
| App::$strings["Ability to display only posts of a specific forum"] = "Posibilidad de mostrar sólo los mensajes de un foro específico"; | App::$strings["Ability to display only posts of a specific forum"] = "Posibilidad de mostrar sólo los mensajes de un foro específico"; | ||||||
| App::$strings["Personal Posts Filter"] = "Filtro de entradas personales"; | App::$strings["Personal Posts Filter"] = "Filtro de entradas personales"; | ||||||
| App::$strings["Ability to display only posts that you've interacted on"] = "Posibilidad de mostrar sólo los mensajes en los que usted haya interactuado"; | App::$strings["Ability to display only posts that you've interacted on"] = "Posibilidad de mostrar sólo los mensajes en los que usted haya interactuado"; | ||||||
| App::$strings["Show friend and connection suggestions"] = "Mostrar sugerencias de amigos y conexiones"; |  | ||||||
| App::$strings["Photo Location"] = "Ubicación de las fotos"; | App::$strings["Photo Location"] = "Ubicación de las fotos"; | ||||||
| App::$strings["If location data is available on uploaded photos, link this to a map."] = "Si los datos de ubicación están disponibles en las fotos subidas, enlazar estas a un mapa."; | App::$strings["If location data is available on uploaded photos, link this to a map."] = "Si los datos de ubicación están disponibles en las fotos subidas, enlazar estas a un mapa."; | ||||||
| App::$strings["Advanced Profiles"] = "Perfiles avanzados"; | App::$strings["Advanced Profiles"] = "Perfiles avanzados"; | ||||||
|   | |||||||
| @@ -1,13 +1,22 @@ | |||||||
| Hola,  | Disculpas, pero esto puede ser urgente. | ||||||
| Soy el servidor web en {{$sitename}}; |  | ||||||
|  |  | ||||||
| Los desarrolladores de Hubzilla lanzaron una actualización {{$update}} recientemente,  | Este es el servidor web en {{$sitename}}; | ||||||
| pero cuando se intentaba instalar, alguna cosa ha ido terriblemente mal.   |     | ||||||
|  | Los desarrolladores del proyecto han publicado recientemente una actualización {{$update}},   | ||||||
|  | pero durante el intento de instalarlo automáticamente, algo salió terriblemente mal.    | ||||||
| Esto requiere intervención humana tan pronto como sea posible.  | Esto requiere intervención humana tan pronto como sea posible.  | ||||||
| Póngase en contacto con un desarrollador de proyectos si no sabe cómo  | Póngase en contacto con un desarrollador de proyectos si no sabe cómo  | ||||||
| por sí mismo. Mi base se datos puede quedar inservible.  | arréglelo por su cuenta. La configuración de la base de datos de su servidor web puede no ser válida.  | ||||||
|  |  | ||||||
| El mensaje de error ha sido el siguiente: '{{$error}}'.    | El mensaje de error ha sido el siguiente: '{{$error}}'.    | ||||||
|  |  | ||||||
|  | Puede intentar volver a aplicar esta actualización visitando  | ||||||
|  |  | ||||||
|  | {{$baseurl}}/admin/dbsync | ||||||
|  |  | ||||||
|  | mientras estaba conectado a la cuenta de administración.  | ||||||
|  |  | ||||||
|  | {{$source}} | ||||||
|  |  | ||||||
| Disculpe por cualquier inconveniente causado,  | Disculpe por cualquier inconveniente causado,  | ||||||
| 	su servidor web en {{$siteurl}} | 	su servidor web en {{$siteurl}} | ||||||
| @@ -17,6 +17,8 @@ var resource = {{$resource}}; | |||||||
| var default_view = resource !== null ? 'timeGridDay' : 'dayGridMonth'; | var default_view = resource !== null ? 'timeGridDay' : 'dayGridMonth'; | ||||||
| var default_date = resource !== null ? new Date(resource.dtstart) : new Date(); | var default_date = resource !== null ? new Date(resource.dtstart) : new Date(); | ||||||
|  |  | ||||||
|  | var allday; | ||||||
|  |  | ||||||
| $(document).ready(function() { | $(document).ready(function() { | ||||||
| 	var calendarEl = document.getElementById('calendar'); | 	var calendarEl = document.getElementById('calendar'); | ||||||
| 	calendar = new FullCalendar.Calendar(calendarEl, { | 	calendar = new FullCalendar.Calendar(calendarEl, { | ||||||
| @@ -43,7 +45,6 @@ $(document).ready(function() { | |||||||
| 		dayNamesShort: aStr['dayNamesShort'], | 		dayNamesShort: aStr['dayNamesShort'], | ||||||
| 		allDayText: aStr['allday'], | 		allDayText: aStr['allday'], | ||||||
|  |  | ||||||
| 		defaultTimedEventDuration: '01:00:00', |  | ||||||
| 		snapDuration: '00:15:00', | 		snapDuration: '00:15:00', | ||||||
| 		 | 		 | ||||||
| 		dateClick: function(info) { | 		dateClick: function(info) { | ||||||
| @@ -53,8 +54,10 @@ $(document).ready(function() { | |||||||
| 				new_event = {}; | 				new_event = {}; | ||||||
| 			} | 			} | ||||||
|  |  | ||||||
|  | 			allday = info.allDay; | ||||||
|  |  | ||||||
| 			var dtend = new Date(info.date.toUTCString()); | 			var dtend = new Date(info.date.toUTCString()); | ||||||
| 			if(info.view.type == 'dayGridMonth') { | 			if(allday) { | ||||||
| 				dtend.setDate(dtend.getDate() + 1); | 				dtend.setDate(dtend.getDate() + 1); | ||||||
| 			} | 			} | ||||||
| 			else{ | 			else{ | ||||||
| @@ -76,12 +79,11 @@ $(document).ready(function() { | |||||||
| 			$('#event_submit').val('create_event').html('{{$create}}'); | 			$('#event_submit').val('create_event').html('{{$create}}'); | ||||||
| 			$('#event_delete').hide(); | 			$('#event_delete').hide(); | ||||||
|  |  | ||||||
| 			new_event = { id: new_event_id, title  : 'New event', start: $('#id_dtstart').val(), end: $('#id_dtend').val(), editable: true, color: '#bbb' }; | 			new_event = { id: new_event_id, title: 'New event', start: $('#id_dtstart').val(), end: $('#id_dtend').val(), allDay: info.allDay, editable: true, color: '#bbb' }; | ||||||
| 			calendar.addEvent(new_event); | 			calendar.addEvent(new_event); | ||||||
| 		}, | 		}, | ||||||
|  |  | ||||||
| 		eventClick: function(info) { | 		eventClick: function(info) { | ||||||
|  |  | ||||||
| 			//reset categories | 			//reset categories | ||||||
| 			$('#id_categories').tagsinput('removeAll'); | 			$('#id_categories').tagsinput('removeAll'); | ||||||
|  |  | ||||||
| @@ -131,6 +133,8 @@ $(document).ready(function() { | |||||||
| 				event_uri = event.extendedProps.uri; | 				event_uri = event.extendedProps.uri; | ||||||
| 				$('#id_title').val(event.title); | 				$('#id_title').val(event.title); | ||||||
| 				$('#calendar_select').val(calendar_id).attr('disabled', true).trigger('change'); | 				$('#calendar_select').val(calendar_id).attr('disabled', true).trigger('change'); | ||||||
|  | 				$('#id_timezone_select').val(event.extendedProps.timezone); | ||||||
|  | 				$('#id_location').val(event.extendedProps.location); | ||||||
| 				$('#id_categories').tagsinput('add', event.extendedProps.categories); | 				$('#id_categories').tagsinput('add', event.extendedProps.categories); | ||||||
| 				$('#id_dtstart').val(dtstart.toUTCString()); | 				$('#id_dtstart').val(dtstart.toUTCString()); | ||||||
| 				$('#id_dtend').val(dtend.toUTCString()); | 				$('#id_dtend').val(dtend.toUTCString()); | ||||||
| @@ -179,6 +183,7 @@ $(document).ready(function() { | |||||||
| 		}, | 		}, | ||||||
| 		 | 		 | ||||||
| 		eventResize: function(info) { | 		eventResize: function(info) { | ||||||
|  | 			console.log(info); | ||||||
|  |  | ||||||
| 			var event = info.event._def; | 			var event = info.event._def; | ||||||
| 			var dtstart = new Date(info.event._instance.range.start); | 			var dtstart = new Date(info.event._instance.range.start); | ||||||
| @@ -199,9 +204,10 @@ $(document).ready(function() { | |||||||
| 					'type': 'event', | 					'type': 'event', | ||||||
| 					'preview': 0, | 					'preview': 0, | ||||||
| 					'summary': event.title, | 					'summary': event.title, | ||||||
|  | 					'timezone_select': event.extendedProps.timezone, | ||||||
| 					'dtstart': dtstart.toUTCString(), | 					'dtstart': dtstart.toUTCString(), | ||||||
| 					'dtend': dtend.toUTCString(), | 					'dtend': dtend.toUTCString(), | ||||||
| 					'adjust': event.extendedProps.item.adjust, | 					'adjust': event.allDay ? 0 : 1, | ||||||
| 					'categories': event.extendedProps.categories, | 					'categories': event.extendedProps.categories, | ||||||
| 					'desc': event.extendedProps.description, | 					'desc': event.extendedProps.description, | ||||||
| 					'location': event.extendedProps.location, | 					'location': event.extendedProps.location, | ||||||
| @@ -215,8 +221,10 @@ $(document).ready(function() { | |||||||
| 					'update': 'resize', | 					'update': 'resize', | ||||||
| 					'id[]': event.extendedProps.calendar_id, | 					'id[]': event.extendedProps.calendar_id, | ||||||
| 					'uri': event.extendedProps.uri, | 					'uri': event.extendedProps.uri, | ||||||
|  | 					'timezone_select': event.extendedProps.timezone, | ||||||
| 					'dtstart': dtstart ? dtstart.toUTCString() : '', | 					'dtstart': dtstart ? dtstart.toUTCString() : '', | ||||||
| 					'dtend': dtend ? dtend.toUTCString() : '' | 					'dtend': dtend ? dtend.toUTCString() : '', | ||||||
|  | 					'allday': event.allDay ? 1 : 0 | ||||||
| 				}) | 				}) | ||||||
| 				.fail(function() { | 				.fail(function() { | ||||||
| 					info.revert(); | 					info.revert(); | ||||||
| @@ -245,9 +253,10 @@ $(document).ready(function() { | |||||||
| 					'type': 'event', | 					'type': 'event', | ||||||
| 					'preview': 0, | 					'preview': 0, | ||||||
| 					'summary': event.title, | 					'summary': event.title, | ||||||
|  | 					'timezone_select': event.extendedProps.timezone, | ||||||
| 					'dtstart': dtstart.toUTCString(), | 					'dtstart': dtstart.toUTCString(), | ||||||
| 					'dtend': dtend.toUTCString(), | 					'dtend': dtend.toUTCString(), | ||||||
| 					'adjust': event.extendedProps.item.adjust, | 					'adjust': event.allDay ? 0 : 1, | ||||||
| 					'categories': event.extendedProps.categories, | 					'categories': event.extendedProps.categories, | ||||||
| 					'desc': event.extendedProps.description, | 					'desc': event.extendedProps.description, | ||||||
| 					'location': event.extendedProps.location, | 					'location': event.extendedProps.location, | ||||||
| @@ -261,8 +270,10 @@ $(document).ready(function() { | |||||||
| 					'update': 'drop', | 					'update': 'drop', | ||||||
| 					'id[]': event.extendedProps.calendar_id, | 					'id[]': event.extendedProps.calendar_id, | ||||||
| 					'uri': event.extendedProps.uri, | 					'uri': event.extendedProps.uri, | ||||||
|  | 					'timezone_select': event.extendedProps.timezone, | ||||||
| 					'dtstart': dtstart ? dtstart.toUTCString() : '', | 					'dtstart': dtstart ? dtstart.toUTCString() : '', | ||||||
| 					'dtend': dtend ? dtend.toUTCString() : '' | 					'dtend': dtend ? dtend.toUTCString() : '', | ||||||
|  | 					'allday': event.allDay ? 1 : 0 | ||||||
| 				}) | 				}) | ||||||
| 				.fail(function() { | 				.fail(function() { | ||||||
| 					info.revert(); | 					info.revert(); | ||||||
| @@ -334,6 +345,7 @@ $(document).ready(function() { | |||||||
| 		$('#id_categories').tagsinput('add', '{{$categories}}'), | 		$('#id_categories').tagsinput('add', '{{$categories}}'), | ||||||
| 		$('#id_description').val(resource.description); | 		$('#id_description').val(resource.description); | ||||||
| 		$('#id_location').val(resource.location); | 		$('#id_location').val(resource.location); | ||||||
|  | 		$('#id_timezone_select').val(resource.timezone); | ||||||
|  |  | ||||||
| 		if(event_xchan !== '{{$channel_hash}}') | 		if(event_xchan !== '{{$channel_hash}}') | ||||||
| 			$('#event_submit').hide(); | 			$('#event_submit').hide(); | ||||||
| @@ -414,10 +426,11 @@ function on_submit() { | |||||||
| 			'xchan': event_xchan, | 			'xchan': event_xchan, | ||||||
| 			'type': 'event', | 			'type': 'event', | ||||||
| 			'preview': 0, | 			'preview': 0, | ||||||
|  | 			'timezone_select': $('#id_timezone_select').val(), | ||||||
| 			'summary': $('#id_title').val(), | 			'summary': $('#id_title').val(), | ||||||
| 			'dtstart': $('#id_dtstart').val(), | 			'dtstart': $('#id_dtstart').val(), | ||||||
| 			'dtend': $('#id_dtend').val(), | 			'dtend': $('#id_dtend').val(), | ||||||
| 			'adjust': 0, | 			'adjust': allday ? 0 : 1, | ||||||
| 			'categories': $('#id_categories').val(), | 			'categories': $('#id_categories').val(), | ||||||
| 			'desc': $('#id_description').val(), | 			'desc': $('#id_description').val(), | ||||||
| 			'location': $('#id_location').val(), | 			'location': $('#id_location').val(), | ||||||
| @@ -439,12 +452,14 @@ function on_submit() { | |||||||
| 		$.post( 'cdav/calendar', { | 		$.post( 'cdav/calendar', { | ||||||
| 			'submit': $('#event_submit').val(), | 			'submit': $('#event_submit').val(), | ||||||
| 			'target': $('#calendar_select').val(), | 			'target': $('#calendar_select').val(), | ||||||
|  | 			'timezone_select': $('#id_timezone_select').val(), | ||||||
| 			'uri': event_uri, | 			'uri': event_uri, | ||||||
| 			'title': $('#id_title').val(), | 			'title': $('#id_title').val(), | ||||||
| 			'dtstart': $('#id_dtstart').val(), | 			'dtstart': $('#id_dtstart').val(), | ||||||
| 			'dtend': $('#id_dtend').val(), | 			'dtend': $('#id_dtend').val(), | ||||||
| 			'description': $('#id_description').val(), | 			'description': $('#id_description').val(), | ||||||
| 			'location': $('#id_location').val() | 			'location': $('#id_location').val(), | ||||||
|  | 			'allday': allday ? 1 : 0 | ||||||
| 		}) | 		}) | ||||||
| 		.done(function() { | 		.done(function() { | ||||||
| 			var parts = $('#calendar_select').val().split(':'); | 			var parts = $('#calendar_select').val().split(':'); | ||||||
| @@ -569,6 +584,9 @@ function exportDate() { | |||||||
| 					{{/foreach}} | 					{{/foreach}} | ||||||
| 					</optgroup> | 					</optgroup> | ||||||
| 				</select> | 				</select> | ||||||
|  | 				{{if $timezone_select}} | ||||||
|  | 				{{include file="field_select_grouped.tpl" field=$timezone_select}} | ||||||
|  | 				{{/if}} | ||||||
| 				<div id="more_block" style="display: none;"> | 				<div id="more_block" style="display: none;"> | ||||||
| 					{{if $catsenabled}} | 					{{if $catsenabled}} | ||||||
| 					<div id="id_categories_wrapper" class="form-group"> | 					<div id="id_categories_wrapper" class="form-group"> | ||||||
|   | |||||||
| @@ -52,6 +52,7 @@ | |||||||
| 			header: false, | 			header: false, | ||||||
| 			eventTextColor: 'white', | 			eventTextColor: 'white', | ||||||
| 			lang: '{{$lang}}', | 			lang: '{{$lang}}', | ||||||
|  | 			timeZone: '{{$timezone}}', | ||||||
| 			firstDay: {{$first_day}}, | 			firstDay: {{$first_day}}, | ||||||
|  |  | ||||||
| 			eventLimit: 3, | 			eventLimit: 3, | ||||||
|   | |||||||
| @@ -1,6 +1,11 @@ | |||||||
| <div class="event-item-title"> | <div class="event-item-title"> | ||||||
| 	<h3><i class="fa fa-calendar"></i> {{$title}}</h3> | 	<h3><i class="fa fa-calendar"></i> {{$title}}</h3> | ||||||
| </div> | </div> | ||||||
|  | {{if $oneday && $allday}} | ||||||
|  | <span class="dtstart">{{$dtstart_dt}}</span> | ||||||
|  | {{else if $allday}} | ||||||
|  | <span class="dtstart">{{$dtstart_dt}}</span> — <span class="dtend">{{$dtend_dt}}</span> | ||||||
|  | {{else}} | ||||||
| <div class="event-item-start"> | <div class="event-item-start"> | ||||||
| 	<span class="event-item-label">{{$dtstart_label}}</span> <span class="dtstart" title="{{$dtstart_title}}">{{$dtstart_dt}}</span> | 	<span class="event-item-label">{{$dtstart_label}}</span> <span class="dtstart" title="{{$dtstart_title}}">{{$dtstart_dt}}</span> | ||||||
| </div> | </div> | ||||||
| @@ -9,3 +14,4 @@ | |||||||
| 	<span class="event-item-label">{{$dtend_label}}</span> <span class="dtend" title="{{$dtend_title}}">{{$dtend_dt}}</span> | 	<span class="event-item-label">{{$dtend_label}}</span> <span class="dtend" title="{{$dtend_title}}">{{$dtend_dt}}</span> | ||||||
| </div> | </div> | ||||||
| {{/if}} | {{/if}} | ||||||
|  | {{/if}} | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user