mirror of
				https://github.com/commons-app/apps-android-commons.git
				synced 2025-10-26 12:23:58 +01:00 
			
		
		
		
	Compare commits
	
		
			6 commits
		
	
	
		
			09c8d987e1
			...
			7d96e94689
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|   | 7d96e94689 | ||
|   | 7a865df909 | ||
|   | 864884e7b2 | ||
|   | 1ecaf09f21 | ||
|   | 1ff2a28326 | ||
|   | b48905a153 | 
					 9 changed files with 50 additions and 201 deletions
				
			
		|  | @ -173,19 +173,13 @@ class BookmarkItemsDao @Inject constructor( | ||||||
|         categoryNameList: List<String>, |         categoryNameList: List<String>, | ||||||
|         categoryDescriptionList: List<String>, |         categoryDescriptionList: List<String>, | ||||||
|         categoryThumbnailList: List<String> |         categoryThumbnailList: List<String> | ||||||
|     ): List<CategoryItem> { |     ): List<CategoryItem> = categoryNameList.mapIndexed { index, name -> | ||||||
|         return buildList { |  | ||||||
|             for (i in categoryNameList.indices) { |  | ||||||
|                 add( |  | ||||||
|         CategoryItem( |         CategoryItem( | ||||||
|                         categoryNameList[i], |             name = name, | ||||||
|                         categoryDescriptionList[i], |             description = categoryDescriptionList.getOrNull(index), | ||||||
|                         categoryThumbnailList[i], |             thumbnail = categoryThumbnailList.getOrNull(index), | ||||||
|                         false |             isSelected = false | ||||||
|         ) |         ) | ||||||
|                 ) |  | ||||||
|             } |  | ||||||
|         } |  | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     /** |     /** | ||||||
|  |  | ||||||
|  | @ -91,6 +91,7 @@ public class NearbyFilterSearchRecyclerViewAdapter | ||||||
|             label.setSelected(!label.isSelected()); |             label.setSelected(!label.isSelected()); | ||||||
|             holder.placeTypeLayout.setSelected(label.isSelected()); |             holder.placeTypeLayout.setSelected(label.isSelected()); | ||||||
| 
 | 
 | ||||||
|  |             NearbyFilterState.setSelectedLabels(new ArrayList<>(selectedLabels)); | ||||||
|             callback.filterByMarkerType(selectedLabels, 0, false, false); |             callback.filterByMarkerType(selectedLabels, 0, false, false); | ||||||
|         }); |         }); | ||||||
|     } |     } | ||||||
|  | @ -152,6 +153,7 @@ public class NearbyFilterSearchRecyclerViewAdapter | ||||||
|             label.setSelected(false); |             label.setSelected(false); | ||||||
|             selectedLabels.remove(label); |             selectedLabels.remove(label); | ||||||
|         } |         } | ||||||
|  |         NearbyFilterState.setSelectedLabels(new ArrayList<>(selectedLabels)); | ||||||
|         notifyDataSetChanged(); |         notifyDataSetChanged(); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  | @ -163,6 +165,7 @@ public class NearbyFilterSearchRecyclerViewAdapter | ||||||
|                 selectedLabels.add(label); |                 selectedLabels.add(label); | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|  |         NearbyFilterState.setSelectedLabels(new ArrayList<>(selectedLabels)); | ||||||
|         notifyDataSetChanged(); |         notifyDataSetChanged(); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -881,6 +881,12 @@ class NearbyParentFragment : CommonsDaggerSupportFragment(), | ||||||
|     fun initNearbyFilter() { |     fun initNearbyFilter() { | ||||||
|         binding!!.nearbyFilterList.root.visibility = View.GONE |         binding!!.nearbyFilterList.root.visibility = View.GONE | ||||||
|         hideBottomSheet() |         hideBottomSheet() | ||||||
|  |         binding!!.nearbyFilter.searchViewLayout.searchView.apply { | ||||||
|  |             setIconifiedByDefault(false) | ||||||
|  |             isIconified = false | ||||||
|  |             setQuery("", false) | ||||||
|  |             clearFocus() | ||||||
|  |         } | ||||||
|         binding!!.nearbyFilter.searchViewLayout.searchView.setOnQueryTextFocusChangeListener { v, hasFocus -> |         binding!!.nearbyFilter.searchViewLayout.searchView.setOnQueryTextFocusChangeListener { v, hasFocus -> | ||||||
|             setLayoutHeightAlignedToWidth( |             setLayoutHeightAlignedToWidth( | ||||||
|                 1.25, |                 1.25, | ||||||
|  | @ -924,6 +930,7 @@ class NearbyParentFragment : CommonsDaggerSupportFragment(), | ||||||
|                     return _isDarkTheme |                     return _isDarkTheme | ||||||
|                 } |                 } | ||||||
|             }) |             }) | ||||||
|  |         restoreStoredFilterSelection() | ||||||
|         binding!!.nearbyFilterList.root |         binding!!.nearbyFilterList.root | ||||||
|             .layoutParams.width = getScreenWidth( |             .layoutParams.width = getScreenWidth( | ||||||
|             requireActivity(), |             requireActivity(), | ||||||
|  | @ -942,6 +949,22 @@ class NearbyParentFragment : CommonsDaggerSupportFragment(), | ||||||
|                 }) |                 }) | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  |     private fun restoreStoredFilterSelection() { | ||||||
|  |         val adapter = nearbyFilterSearchRecyclerViewAdapter ?: return | ||||||
|  |         val savedLabels = ArrayList(NearbyFilterState.getInstance().selectedLabels) | ||||||
|  |         adapter.selectedLabels.clear() | ||||||
|  |         val savedSet = savedLabels.toSet() | ||||||
|  |         Label.valuesAsList().forEach { label -> | ||||||
|  |             val isSelected = savedSet.contains(label) | ||||||
|  |             label.setSelected(isSelected) | ||||||
|  |             if (isSelected) { | ||||||
|  |                 adapter.selectedLabels.add(label) | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |         NearbyFilterState.setSelectedLabels(ArrayList(adapter.selectedLabels)) | ||||||
|  |         adapter.notifyDataSetChanged() | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|     override fun setCheckBoxAction() { |     override fun setCheckBoxAction() { | ||||||
|         binding!!.nearbyFilterList.checkboxTriStates.addAction() |         binding!!.nearbyFilterList.checkboxTriStates.addAction() | ||||||
|         binding!!.nearbyFilterList.checkboxTriStates.state = CheckBoxTriStates.UNKNOWN |         binding!!.nearbyFilterList.checkboxTriStates.state = CheckBoxTriStates.UNKNOWN | ||||||
|  |  | ||||||
|  | @ -34,12 +34,12 @@ | ||||||
|   </plurals> |   </plurals> | ||||||
|   <string name="starting_uploads">Starting Uploads</string> |   <string name="starting_uploads">Starting Uploads</string> | ||||||
|   <plurals name="starting_multiple_uploads"> |   <plurals name="starting_multiple_uploads"> | ||||||
|     <item quantity="one">Processing %d upload</item> |     <item quantity="one">Processing %1$d upload</item> | ||||||
|     <item quantity="other">Processing %d uploads</item> |     <item quantity="other">Processing %1$d uploads</item> | ||||||
|   </plurals> |   </plurals> | ||||||
|   <plurals name="multiple_uploads_title"> |   <plurals name="multiple_uploads_title"> | ||||||
|     <item quantity="one">%d upload</item> |     <item quantity="one">%1$d upload</item> | ||||||
|     <item quantity="other">%d uploads</item> |     <item quantity="other">%1$d uploads</item> | ||||||
|   </plurals> |   </plurals> | ||||||
|   <plurals name="share_license_summary"> |   <plurals name="share_license_summary"> | ||||||
|     <item quantity="one">This image will be licensed under %1$s</item> |     <item quantity="one">This image will be licensed under %1$s</item> | ||||||
|  | @ -83,7 +83,7 @@ | ||||||
|   <string name="uploading_queued">Upload queued (limited connection mode enabled)</string> |   <string name="uploading_queued">Upload queued (limited connection mode enabled)</string> | ||||||
|   <string name="upload_completed_notification_title">%1$s uploaded!</string> |   <string name="upload_completed_notification_title">%1$s uploaded!</string> | ||||||
|   <string name="upload_completed_notification_text">Tap to view your upload</string> |   <string name="upload_completed_notification_text">Tap to view your upload</string> | ||||||
|   <string name="upload_progress_notification_title_start">Uploading file: %s</string> |   <string name="upload_progress_notification_title_start">Uploading file: %1$s</string> | ||||||
|   <string name="upload_progress_notification_title_in_progress">%1$s uploading</string> |   <string name="upload_progress_notification_title_in_progress">%1$s uploading</string> | ||||||
|   <string name="upload_progress_notification_title_finishing">Finishing uploading %1$s</string> |   <string name="upload_progress_notification_title_finishing">Finishing uploading %1$s</string> | ||||||
|   <string name="upload_failed_notification_title">Failed to upload %1$s</string> |   <string name="upload_failed_notification_title">Failed to upload %1$s</string> | ||||||
|  | @ -233,8 +233,8 @@ | ||||||
|   <string name="welcome_image_llamas">Llamas</string> |   <string name="welcome_image_llamas">Llamas</string> | ||||||
|   <string name="welcome_image_rainbow_bridge">Rainbow Bridge</string> |   <string name="welcome_image_rainbow_bridge">Rainbow Bridge</string> | ||||||
|   <string name="welcome_image_tulip">Tulip</string> |   <string name="welcome_image_tulip">Tulip</string> | ||||||
|   <string name="welcome_image_welcome_wikipedia">Welcome Wikipedia</string> |   <string name="welcome_image_welcome_wikipedia">A schematic image of a generic Wikipedia article.</string> | ||||||
|   <string name="welcome_image_welcome_copyright">Welcome Copyright</string> |   <string name="welcome_image_welcome_copyright">A drawing of a stack of papers with the copyright symbol crossed out.</string> | ||||||
|   <string name="welcome_image_sydney_opera_house">Sydney Opera House</string> |   <string name="welcome_image_sydney_opera_house">Sydney Opera House</string> | ||||||
|   <string name="cancel">Cancel</string> |   <string name="cancel">Cancel</string> | ||||||
|   <string name="navigation_drawer_open">Open</string> |   <string name="navigation_drawer_open">Open</string> | ||||||
|  | @ -388,9 +388,9 @@ | ||||||
|   <string name="statistics_thanks">Thanks Received</string> |   <string name="statistics_thanks">Thanks Received</string> | ||||||
|   <string name="statistics_featured">Featured Images</string> |   <string name="statistics_featured">Featured Images</string> | ||||||
|   <string name="statistics_wikidata_edits">Images via \"Nearby Places\"</string> |   <string name="statistics_wikidata_edits">Images via \"Nearby Places\"</string> | ||||||
|   <string name="level">Level %d</string> |   <string name="level">Level %1$d</string> | ||||||
|   <string name="profile_withLevel">%s (Level %s)</string> |   <string name="profile_withLevel">%1$s (Level %2$s)</string> | ||||||
|   <string name="profile_withoutLevel">%s (%s)</string> |   <string name="profile_withoutLevel">%1$s (%2$s)</string> | ||||||
|   <string name="images_uploaded">Images Uploaded</string> |   <string name="images_uploaded">Images Uploaded</string> | ||||||
|   <string name="image_reverts">Images Not Reverted</string> |   <string name="image_reverts">Images Not Reverted</string> | ||||||
|   <string name="images_used_by_wiki">Images Used</string> |   <string name="images_used_by_wiki">Images Used</string> | ||||||
|  | @ -610,7 +610,7 @@ Upload your first media by tapping on the add button.</string> | ||||||
| 
 | 
 | ||||||
|   <string name="share_image_via">Share image via</string> |   <string name="share_image_via">Share image via</string> | ||||||
|   <string name="you_have_no_achievements_yet">You haven\'t made any contributions yet</string> |   <string name="you_have_no_achievements_yet">You haven\'t made any contributions yet</string> | ||||||
|   <string name="no_achievements_yet">%s has not made any contributions yet</string> |   <string name="no_achievements_yet">%1$s has not made any contributions yet</string> | ||||||
|   <string name="account_created">Account created!</string> |   <string name="account_created">Account created!</string> | ||||||
|   <string name="text_copy">Text copied to clipboard</string> |   <string name="text_copy">Text copied to clipboard</string> | ||||||
|   <string name="notification_mark_read">Notification marked as read</string> |   <string name="notification_mark_read">Notification marked as read</string> | ||||||
|  | @ -757,8 +757,8 @@ Upload your first media by tapping on the add button.</string> | ||||||
|   <string name="location_off_dialog_text">Please turn on location services to view nearby places.</string> |   <string name="location_off_dialog_text">Please turn on location services to view nearby places.</string> | ||||||
|   <string name="location_permission_rationale">Location access is needed to show nearby places on the map.</string> |   <string name="location_permission_rationale">Location access is needed to show nearby places on the map.</string> | ||||||
| 
 | 
 | ||||||
|   <string name="contributions_of_user">Contributions of User: %s</string> |   <string name="contributions_of_user">Contributions of User: %1$s</string> | ||||||
|   <string name="achievements_of_user">Achievements of User: %s</string> |   <string name="achievements_of_user">Achievements of User: %1$s</string> | ||||||
|   <string name="menu_view_user_page">View user profile</string> |   <string name="menu_view_user_page">View user profile</string> | ||||||
|   <string name="edit_depictions">Edit depictions</string> |   <string name="edit_depictions">Edit depictions</string> | ||||||
|   <string name="edit_categories">Edit categories</string> |   <string name="edit_categories">Edit categories</string> | ||||||
|  | @ -834,8 +834,8 @@ Upload your first media by tapping on the add button.</string> | ||||||
|   <string name="saving_kml_file">Saving as a KML file...</string> |   <string name="saving_kml_file">Saving as a KML file...</string> | ||||||
|   <string name="saving_gpx_file">Saving as a GPX file...</string> |   <string name="saving_gpx_file">Saving as a GPX file...</string> | ||||||
|   <plurals name="custom_picker_images_selected_title_appendix"> |   <plurals name="custom_picker_images_selected_title_appendix"> | ||||||
|     <item quantity="one">%d image selected</item> |     <item quantity="one">%1$d image selected</item> | ||||||
|     <item quantity="other">%d images selected</item> |     <item quantity="other">%1$d images selected</item> | ||||||
|   </plurals> |   </plurals> | ||||||
|   <string name="multiple_files_depiction">Please remember that all images in a multi-upload get the same categories and depictions. If the images do not share depictions and categories, please perform several separate uploads.</string> |   <string name="multiple_files_depiction">Please remember that all images in a multi-upload get the same categories and depictions. If the images do not share depictions and categories, please perform several separate uploads.</string> | ||||||
|   <string name="multiple_files_depiction_header">Note about multi-uploads</string> |   <string name="multiple_files_depiction_header">Note about multi-uploads</string> | ||||||
|  |  | ||||||
|  | @ -1,18 +0,0 @@ | ||||||
| <?xml version="1.0" encoding="utf-8"?> |  | ||||||
| <licenses xmlns="https://www.mediawiki.org/wiki/Extension:UploadWizard/xmlns/licenses"> |  | ||||||
|   <license id="cc-by-4.0" template="cc-by-4.0" url="https://creativecommons.org/licenses/by/4.0/deed.$lang"/> |  | ||||||
|   <license id="cc-by-sa-4.0" template="cc-by-sa-4.0" url="https://creativecommons.org/licenses/by-sa/4.0/deed.$lang"/> |  | ||||||
|   <license id="cc-by-sa-3.0" template="cc-by-sa-3.0" url="https://creativecommons.org/licenses/by-sa/3.0/deed.$lang"/> |  | ||||||
|   <license id="cc-by-sa-3.0-at" template="cc-by-sa-3.0-at" url="https://creativecommons.org/licenses/by-sa/3.0/at/deed.$lang"/> |  | ||||||
|   <license id="cc-by-sa-3.0-de" template="cc-by-sa-3.0-de" url="https://creativecommons.org/licenses/by-sa/3.0/de/deed.$lang"/> |  | ||||||
|   <license id="cc-by-sa-3.0-ee" template="cc-by-sa-3.0-ee" url="https://creativecommons.org/licenses/by-sa/3.0/ee/deed.$lang"/> |  | ||||||
|   <license id="cc-by-sa-3.0-es" template="cc-by-sa-3.0-es" url="https://creativecommons.org/licenses/by-sa/3.0/es/deed.$lang"/> |  | ||||||
|   <license id="cc-by-sa-3.0-hr" template="cc-by-sa-3.0-hr" url="https://creativecommons.org/licenses/by-sa/3.0/hr/deed.$lang"/> |  | ||||||
|   <license id="cc-by-sa-3.0-lu" template="cc-by-sa-3.0-lu" url="https://creativecommons.org/licenses/by-sa/3.0/lu/deed.$lang"/> |  | ||||||
|   <license id="cc-by-sa-3.0-nl" template="cc-by-sa-3.0-nl" url="https://creativecommons.org/licenses/by-sa/3.0/nl/deed.$lang"/> |  | ||||||
|   <license id="cc-by-sa-3.0-no" template="cc-by-sa-3.0-no" url="https://creativecommons.org/licenses/by-sa/3.0/no/deed.$lang"/> |  | ||||||
|   <license id="cc-by-sa-3.0-pl" template="cc-by-sa-3.0-pl" url="https://creativecommons.org/licenses/by-sa/3.0/pl/deed.$lang"/> |  | ||||||
|   <license id="cc-by-sa-3.0-ro" template="cc-by-sa-3.0-ro" url="https://creativecommons.org/licenses/by-sa/3.0/ro/deed.$lang"/> |  | ||||||
|   <license id="cc-by-3.0" template="cc-by-3.0" url="https://creativecommons.org/licenses/by/3.0/deed.$lang"/> |  | ||||||
|   <license id="cc-zero" template="cc-zero" url="https://creativecommons.org/publicdomain/zero/1.0/deed.$lang"/> |  | ||||||
| </licenses> |  | ||||||
|  | @ -1,14 +0,0 @@ | ||||||
| .FAKE : build update clean install |  | ||||||
| 
 |  | ||||||
| build : ../app/src/main/res/xml/wikimedia_licenses.xml |  | ||||||
| 
 |  | ||||||
| ../app/src/main/res/xml/wikimedia_licenses.xml : licenses.php mediawiki-extensions-UploadWizard |  | ||||||
| 	php licenses.php > ../app/src/main/res/xml/wikimedia_licenses.xml |  | ||||||
| 
 |  | ||||||
| mediawiki-extensions-UploadWizard : update |  | ||||||
| 
 |  | ||||||
| update : |  | ||||||
| 	if [ -d mediawiki-extensions-UploadWizard ]; then (cd mediawiki-extensions-UploadWizard && git pull origin master); else git clone https://gerrit.wikimedia.org/r/mediawiki/extensions/UploadWizard mediawiki-extensions-UploadWizard; fi |  | ||||||
| 
 |  | ||||||
| clean : |  | ||||||
| 	rm -rf mediawiki-extensions-UploadWizard |  | ||||||
|  | @ -1,68 +0,0 @@ | ||||||
| <?php |  | ||||||
| 
 |  | ||||||
| // Stubs for enough of the MediaWiki environment to run UploadWizard.config.php
 |  | ||||||
| 
 |  | ||||||
| global $wgFileExtensions, $wgServer, $wgScriptPath, $wgAPIModules, $wgMaxUploadSize, $wgLang, $wgMemc, $wgUploadWizardConfig; |  | ||||||
| 
 |  | ||||||
| class FakeLang { |  | ||||||
| 	function getCode() { |  | ||||||
| 		return 'en'; |  | ||||||
| 	} |  | ||||||
| } |  | ||||||
| $wgLang = new FakeLang(); |  | ||||||
| 
 |  | ||||||
| function wfMemcKey() { |  | ||||||
| 	return 'fake-key'; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| class FakeMemc { |  | ||||||
| 	function get() { |  | ||||||
| 		return array( 'en' => 'English' ); |  | ||||||
| 	} |  | ||||||
| } |  | ||||||
| $wgMemc = new FakeMemc(); |  | ||||||
| 
 |  | ||||||
| class FakeMessage { |  | ||||||
| 	function plain() { |  | ||||||
| 		return 'stub-message-plain'; |  | ||||||
| 	} |  | ||||||
| 	function parse() { |  | ||||||
| 		return 'stub-message-parsed'; |  | ||||||
| 	} |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| function wfMessage() { |  | ||||||
| 	return new FakeMessage(); |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| /** |  | ||||||
|  * Converts shorthand byte notation to integer form |  | ||||||
|  * |  | ||||||
|  * @param $string String |  | ||||||
|  * @return Integer |  | ||||||
|  */ |  | ||||||
| function wfShorthandToInteger( $string = '' ) { |  | ||||||
| 	$string = trim( $string ); |  | ||||||
| 	if ( $string === '' ) { |  | ||||||
| 		return -1; |  | ||||||
| 	} |  | ||||||
| 	$last = $string[strlen( $string ) - 1]; |  | ||||||
| 	$val = intval( $string ); |  | ||||||
| 	switch ( $last ) { |  | ||||||
| 		case 'g': |  | ||||||
| 		case 'G': |  | ||||||
| 			$val *= 1024; |  | ||||||
| 			// break intentionally missing
 |  | ||||||
| 		case 'm': |  | ||||||
| 		case 'M': |  | ||||||
| 			$val *= 1024; |  | ||||||
| 			// break intentionally missing
 |  | ||||||
| 		case 'k': |  | ||||||
| 		case 'K': |  | ||||||
| 			$val *= 1024; |  | ||||||
| 	} |  | ||||||
| 
 |  | ||||||
| 	return $val; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| $wgAPIModules = array(); |  | ||||||
|  | @ -1,71 +0,0 @@ | ||||||
| <?php |  | ||||||
| 
 |  | ||||||
| // Quick hack to extract default license list from UploadWizard configuration.
 |  | ||||||
| // In future, try to export this info via the API on wiki so we can pull dynamically.
 |  | ||||||
| //
 |  | ||||||
| // Brion Vibber <brion@pobox.com>
 |  | ||||||
| // 2013-09-30
 |  | ||||||
| 
 |  | ||||||
| require 'include-stubs.php'; |  | ||||||
| $config = require "mediawiki-extensions-UploadWizard/UploadWizard.config.php"; |  | ||||||
| require "mediawiki-extensions-UploadWizard/UploadWizard.i18n.php"; |  | ||||||
| $licenseList = array(); |  | ||||||
| 
 |  | ||||||
| foreach ( $config['licenses'] as $key => $license ) { |  | ||||||
| 	// Determine template -> license mappings
 |  | ||||||
| 	if ( isset( $license['templates'] ) ) { |  | ||||||
| 		$templates = $license['templates']; |  | ||||||
| 	} else { |  | ||||||
| 		$templates = array( $key ); |  | ||||||
| 	} |  | ||||||
| 	 |  | ||||||
| 	if ( count( $templates ) < 1 ) { |  | ||||||
| 		throw new Exception("No templates for $key, this is wrong."); |  | ||||||
| 	} |  | ||||||
| 	if ( count( $templates ) > 1 ) { |  | ||||||
| 		//echo "Skipping multi-template license: $key\n";
 |  | ||||||
| 		continue; |  | ||||||
| 	} |  | ||||||
| 	$template = $templates[0]; |  | ||||||
| 	if ( preg_match( '/^subst:/i', $template ) ) { |  | ||||||
| 		//echo "Skipping subst license: $key\n";
 |  | ||||||
| 		continue; |  | ||||||
| 	} |  | ||||||
| 
 |  | ||||||
| 	$msg = $messages['en'][$license['msg']]; |  | ||||||
| 
 |  | ||||||
| 	$licenseInfo = array( |  | ||||||
| 		'desc' => $msg, |  | ||||||
| 		'template' => $template |  | ||||||
| 	); |  | ||||||
| 	if ( isset( $license['url'] ) ) { |  | ||||||
| 		$url = $license['url']; |  | ||||||
| 		if ( substr( $url, 0, 2 ) == '//' ) { |  | ||||||
| 			$url = 'https:' . $url; |  | ||||||
| 		} |  | ||||||
| 		if ( isset( $license['languageCodePrefix'] ) ) { |  | ||||||
| 			$url .= $license['languageCodePrefix'] . '$lang'; |  | ||||||
| 		} |  | ||||||
| 		$licenseInfo['url'] = $url; |  | ||||||
| 	} |  | ||||||
| 	$licenseList[$key] = $licenseInfo; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| //var_dump( $licenseList );
 |  | ||||||
| 
 |  | ||||||
| echo "<?xml version=\"1.0\" encoding=\"utf-8\"?>\n"; |  | ||||||
| echo "<licenses xmlns=\"https://www.mediawiki.org/wiki/Extension:UploadWizard/xmlns/licenses\">\n"; |  | ||||||
| foreach( $licenseList as $key => $licenseInfo ) { |  | ||||||
| 	$encId = htmlspecialchars( $key ); |  | ||||||
| 	echo "  <license id=\"$encId\"";
 |  | ||||||
| 	$encTemplate = htmlspecialchars( $licenseInfo['template'] ); |  | ||||||
| 	echo " template=\"$encTemplate\"";
 |  | ||||||
| 	if ( isset( $licenseInfo['url'] ) ) { |  | ||||||
| 		$encUrl = htmlspecialchars( $licenseInfo['url'] ); |  | ||||||
| 		echo " url=\"$encUrl\"";
 |  | ||||||
| 	} |  | ||||||
| 	echo "/>\n"; |  | ||||||
| 	 |  | ||||||
| } |  | ||||||
| echo "</licenses>\n"; |  | ||||||
| 	 |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue