mirror of
				https://github.com/InsanusMokrassar/KotlinPublicationScriptsBuilder.git
				synced 2025-10-25 16:20:02 +00:00 
			
		
		
		
	Compare commits
	
		
			6 Commits
		
	
	
		
			build-46d6
			...
			build-9a95
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| 9a95bddf08 | |||
| c880d8e657 | |||
| ac87a140cc | |||
| 0dbe3a866b | |||
| 7c50c58a90 | |||
| ceff1eb1ef | 
							
								
								
									
										1
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										1
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							| @@ -10,3 +10,4 @@ build/ | ||||
| out/ | ||||
|  | ||||
| local.properties | ||||
| kotlin-js-store/ | ||||
|   | ||||
| @@ -1,6 +1,5 @@ | ||||
| buildscript { | ||||
|     repositories { | ||||
|         jcenter() | ||||
|         google() | ||||
|         mavenCentral() | ||||
|         mavenLocal() | ||||
| @@ -8,7 +7,7 @@ buildscript { | ||||
|     } | ||||
|  | ||||
|     dependencies { | ||||
|         classpath 'com.android.tools.build:gradle:4.0.2' | ||||
|         classpath 'com.android.tools.build:gradle:7.0.4' | ||||
|         classpath "org.jetbrains.kotlin:kotlin-gradle-plugin:$kotlin_version" | ||||
|         classpath "org.jetbrains.kotlin:kotlin-serialization:$kotlin_version" | ||||
|         classpath "com.getkeepsafe.dexcount:dexcount-gradle-plugin:$dexcount_version" | ||||
| @@ -19,10 +18,8 @@ buildscript { | ||||
| allprojects { | ||||
|     repositories { | ||||
|         mavenLocal() | ||||
|         jcenter() | ||||
|         mavenCentral() | ||||
|         google() | ||||
|         maven { url "https://kotlin.bintray.com/kotlinx" } | ||||
|         maven { url "https://maven.pkg.jetbrains.space/public/p/compose/dev" } | ||||
|     } | ||||
| } | ||||
|   | ||||
| @@ -0,0 +1,27 @@ | ||||
| package dev.inmo.kmppscriptbuilder.core.export | ||||
|  | ||||
| import dev.inmo.kmppscriptbuilder.core.models.GpgSigning | ||||
|  | ||||
| fun GpgSigning.generateMavenConfig() = when (this) { | ||||
|     GpgSigning.Disabled -> "" | ||||
|     GpgSigning.Optional -> | ||||
| """ | ||||
| if (project.hasProperty("signing.gnupg.keyName")) { | ||||
|     apply plugin: 'signing' | ||||
|      | ||||
|     signing { | ||||
|         useGpgCmd() | ||||
|      | ||||
|         sign publishing.publications | ||||
|     } | ||||
| }""" | ||||
|     GpgSigning.Enabled -> | ||||
| """ | ||||
| apply plugin: 'signing' | ||||
|  | ||||
| signing { | ||||
|     useGpgCmd() | ||||
|  | ||||
|     sign publishing.publications | ||||
| }""" | ||||
| } | ||||
| @@ -0,0 +1,67 @@ | ||||
| package dev.inmo.kmppscriptbuilder.core.export.js_only | ||||
|  | ||||
| import dev.inmo.kmppscriptbuilder.core.export.generateMavenConfig | ||||
| import dev.inmo.kmppscriptbuilder.core.models.* | ||||
|  | ||||
| fun MavenConfig.buildJsOnlyMavenConfig(licenses: List<License>): String = """ | ||||
| apply plugin: 'maven-publish' | ||||
|  | ||||
| task javadocJar(type: Jar) { | ||||
|     classifier = 'javadoc' | ||||
| } | ||||
| task sourcesJar(type: Jar) { | ||||
|     kotlin.sourceSets.all { | ||||
|         from(kotlin) | ||||
|     } | ||||
|     classifier = 'sources' | ||||
| } | ||||
|  | ||||
| publishing { | ||||
|     publications { | ||||
|         maven(MavenPublication) { | ||||
|             kotlin.js().components.forEach { | ||||
|                 from(it) | ||||
|             } | ||||
|  | ||||
|             artifact javadocJar | ||||
|             artifact sourcesJar | ||||
|  | ||||
|             pom { | ||||
|                 resolveStrategy = Closure.DELEGATE_FIRST | ||||
|  | ||||
|                 description = "$description" | ||||
|                 name = "$name" | ||||
|                 url = "$url" | ||||
|  | ||||
|                 scm { | ||||
|                     developerConnection = "scm:git:[fetch=]${vcsUrl}[push=]${vcsUrl}" | ||||
|                     url = "$vcsUrl" | ||||
|                 } | ||||
|  | ||||
|                 developers { | ||||
|                     ${developers.joinToString("\n") { """ | ||||
|                         developer { | ||||
|                             id = "${it.id}" | ||||
|                             name = "${it.name}" | ||||
|                             email = "${it.eMail}" | ||||
|                         } | ||||
|                     """ }} | ||||
|                 } | ||||
|  | ||||
|                 licenses { | ||||
|                     ${licenses.joinToString("\n") { """ | ||||
|                         license { | ||||
|                             name = "${it.title}" | ||||
|                             url = "${it.url}" | ||||
|                         } | ||||
|                     """ }} | ||||
|                 } | ||||
|             } | ||||
|             repositories { | ||||
|                 ${repositories.joinToString("\n                    ") { it.build("                    ") }} | ||||
|             } | ||||
|         } | ||||
|     } | ||||
| } | ||||
| ${gpgSigning.generateMavenConfig()} | ||||
| """.trimIndent() | ||||
| @@ -1,21 +1,21 @@ | ||||
| package dev.inmo.kmppscriptbuilder.core.export.jvm_only | ||||
|  | ||||
| import dev.inmo.kmppscriptbuilder.core.export.generateMavenConfig | ||||
| import dev.inmo.kmppscriptbuilder.core.models.* | ||||
|  | ||||
| fun MavenConfig.buildJvmOnlyMavenConfig(licenses: List<License>): String = """ | ||||
|     apply plugin: 'maven-publish' | ||||
|     ${if (includeGpgSigning) "apply plugin: 'signing'\n" else ""} | ||||
| apply plugin: 'maven-publish' | ||||
|  | ||||
|     task javadocJar(type: Jar) { | ||||
| task javadocJar(type: Jar) { | ||||
|     from javadoc | ||||
|     classifier = 'javadoc' | ||||
|     } | ||||
|     task sourcesJar(type: Jar) { | ||||
| } | ||||
| task sourcesJar(type: Jar) { | ||||
|     from sourceSets.main.allSource | ||||
|     classifier = 'sources' | ||||
|     } | ||||
| } | ||||
|  | ||||
|     publishing { | ||||
| publishing { | ||||
|     publications { | ||||
|         maven(MavenPublication) { | ||||
|             from components.java | ||||
| @@ -59,11 +59,6 @@ fun MavenConfig.buildJvmOnlyMavenConfig(licenses: List<License>): String = """ | ||||
|             } | ||||
|         } | ||||
|     } | ||||
|     } | ||||
|     ${if (includeGpgSigning) """ | ||||
|     signing { | ||||
|         useGpgCmd() | ||||
|         sign publishing.publications | ||||
|     } | ||||
|     """ else ""} | ||||
| } | ||||
| ${gpgSigning.generateMavenConfig()} | ||||
| """.trimIndent() | ||||
| @@ -1,15 +1,16 @@ | ||||
| package dev.inmo.kmppscriptbuilder.core.export.mpp | ||||
|  | ||||
| import dev.inmo.kmppscriptbuilder.core.export.generateMavenConfig | ||||
| import dev.inmo.kmppscriptbuilder.core.models.* | ||||
|  | ||||
| fun MavenConfig.buildMultiplatformMavenConfig(licenses: List<License>): String = """ | ||||
|     apply plugin: 'maven-publish' | ||||
|     ${if (includeGpgSigning) "apply plugin: 'signing'\n" else ""} | ||||
|     task javadocsJar(type: Jar) { | ||||
|         classifier = 'javadoc' | ||||
|     } | ||||
| apply plugin: 'maven-publish' | ||||
|  | ||||
|     publishing { | ||||
| task javadocsJar(type: Jar) { | ||||
|     classifier = 'javadoc' | ||||
| } | ||||
|  | ||||
| publishing { | ||||
|     publications.all { | ||||
|         artifact javadocsJar | ||||
|  | ||||
| @@ -46,11 +47,6 @@ fun MavenConfig.buildMultiplatformMavenConfig(licenses: List<License>): String = | ||||
|             ${repositories.joinToString("\n                ") { it.build("                ") }} | ||||
|         } | ||||
|     } | ||||
|     } | ||||
|     ${if (includeGpgSigning) """ | ||||
|     signing { | ||||
|         useGpgCmd() | ||||
|         sign publishing.publications | ||||
|     } | ||||
|     """ else ""} | ||||
| } | ||||
|     ${gpgSigning.generateMavenConfig()} | ||||
| """.trimIndent() | ||||
| @@ -1,5 +1,6 @@ | ||||
| package dev.inmo.kmppscriptbuilder.core.models | ||||
|  | ||||
| import dev.inmo.kmppscriptbuilder.core.export.js_only.buildJsOnlyMavenConfig | ||||
| import dev.inmo.kmppscriptbuilder.core.export.jvm_only.buildJvmOnlyMavenConfig | ||||
| import dev.inmo.kmppscriptbuilder.core.export.mpp.buildMultiplatformMavenConfig | ||||
| import kotlinx.serialization.* | ||||
| @@ -32,12 +33,6 @@ object ProjectTypeSerializer : KSerializer<ProjectType> { | ||||
|  | ||||
| object MultiplatformProjectType : ProjectType() { | ||||
|     override val name: String = "Multiplatform" | ||||
| //    override fun buildBintrayGradleConfig( | ||||
| //        bintrayConfig: BintrayConfig, | ||||
| //        licenses: List<License> | ||||
| //    ): String = bintrayConfig.buildMultiplatformGradleConfig( | ||||
| //        licenses | ||||
| //    ) | ||||
|  | ||||
|     override fun buildMavenGradleConfig( | ||||
|         mavenConfig: MavenConfig, | ||||
| @@ -49,12 +44,6 @@ object MultiplatformProjectType : ProjectType() { | ||||
|  | ||||
| object JVMProjectType : ProjectType() { | ||||
|     override val name: String = "JVM" | ||||
| //    override fun buildBintrayGradleConfig( | ||||
| //        bintrayConfig: BintrayConfig, | ||||
| //        licenses: List<License> | ||||
| //    ): String = bintrayConfig.buildJvmOnlyGradleConfig( | ||||
| //        licenses | ||||
| //    ) | ||||
|  | ||||
|     override fun buildMavenGradleConfig( | ||||
|         mavenConfig: MavenConfig, | ||||
| @@ -64,6 +53,15 @@ object JVMProjectType : ProjectType() { | ||||
|     ) | ||||
| } | ||||
|  | ||||
| object JSProjectType : ProjectType() { | ||||
|     override val name: String = "JS" | ||||
|  | ||||
|     override fun buildMavenGradleConfig( | ||||
|         mavenConfig: MavenConfig, | ||||
|         licenses: List<License> | ||||
|     ): String = mavenConfig.buildJsOnlyMavenConfig(licenses) | ||||
| } | ||||
|  | ||||
| @Serializable | ||||
| data class Config( | ||||
|     val licenses: List<License>, | ||||
|   | ||||
| @@ -30,19 +30,19 @@ suspend fun HttpClient.getLicenses(): Map<String, License> { | ||||
|  | ||||
| suspend fun HttpClient.searchLicense(name: String): List<License> { | ||||
|     val licenses = licenses ?: getLicenses() | ||||
|     val lowerCase = name.toLowerCase() | ||||
|     val upperCase = name.toUpperCase() | ||||
|     val lowerCase = name.lowercase() | ||||
|     val upperCase = name.uppercase() | ||||
|     return licenses.values.filter { | ||||
|         it.title.toLowerCase().contains(lowerCase) || it.title.toUpperCase().contains(upperCase) || it.title.contains(name) | ||||
|             || it.id.toLowerCase().contains(lowerCase) || it.id.toUpperCase().contains(upperCase) || it.id.contains(name) | ||||
|         it.title.lowercase().contains(lowerCase) || it.title.uppercase().contains(upperCase) || it.title.contains(name) | ||||
|             || it.id.lowercase().contains(lowerCase) || it.id.uppercase().contains(upperCase) || it.id.contains(name) | ||||
|     } | ||||
| } | ||||
|  | ||||
| fun Map<String, License>.searchLicense(name: String): List<License> { | ||||
|     val lowerCase = name.toLowerCase() | ||||
|     val upperCase = name.toUpperCase() | ||||
|     val lowerCase = name.lowercase() | ||||
|     val upperCase = name.uppercase() | ||||
|     return values.filter { | ||||
|         it.title.toLowerCase().contains(lowerCase) || it.title.toUpperCase().contains(upperCase) || it.title.contains(name) | ||||
|             || it.id.toLowerCase().contains(lowerCase) || it.id.toUpperCase().contains(upperCase) || it.id.contains(name) | ||||
|         it.title.lowercase().contains(lowerCase) || it.title.uppercase().contains(upperCase) || it.title.contains(name) | ||||
|             || it.id.lowercase().contains(lowerCase) || it.id.uppercase().contains(upperCase) || it.id.contains(name) | ||||
|     } | ||||
| } | ||||
|   | ||||
| @@ -2,15 +2,30 @@ package dev.inmo.kmppscriptbuilder.core.models | ||||
|  | ||||
| import kotlinx.serialization.Serializable | ||||
|  | ||||
| const val defaultProjectName = "\${project.name}" | ||||
| const val defaultProjectDescription = "\${project.name}" | ||||
|  | ||||
| @Serializable | ||||
| sealed class GpgSigning { | ||||
|     @Serializable | ||||
|     object Disabled : GpgSigning() | ||||
|     @Serializable | ||||
|     object Optional : GpgSigning() | ||||
|     @Serializable | ||||
|     object Enabled : GpgSigning() | ||||
| } | ||||
|  | ||||
| @Serializable | ||||
| data class MavenConfig( | ||||
|     val name: String, | ||||
|     val description: String, | ||||
|     val url: String, | ||||
|     val vcsUrl: String, | ||||
|     val includeGpgSigning: Boolean = false, | ||||
|     val developers: List<Developer>, | ||||
|     val repositories: List<MavenPublishingRepository> = emptyList() | ||||
|     val repositories: List<MavenPublishingRepository> = emptyList(), | ||||
|     val gpgSigning: GpgSigning = GpgSigning.Disabled, | ||||
|     @Deprecated("Replaced with gpgSigning") | ||||
|     val includeGpgSigning: Boolean = false, | ||||
| ) | ||||
|  | ||||
| @Serializable | ||||
|   | ||||
| @@ -10,7 +10,6 @@ kotlin { | ||||
|     jvm { | ||||
|         compilations.main.kotlinOptions { | ||||
|             jvmTarget = "11" | ||||
|             useIR = true | ||||
|         } | ||||
|     } | ||||
|     sourceSets { | ||||
|   | ||||
| @@ -1,20 +1,24 @@ | ||||
| package dev.inmo.kmppscriptbuilder.desktop | ||||
|  | ||||
| import androidx.compose.desktop.Window | ||||
| import androidx.compose.foundation.* | ||||
| import androidx.compose.foundation.layout.* | ||||
| import androidx.compose.material.* | ||||
| import androidx.compose.material.Colors | ||||
| import androidx.compose.material.MaterialTheme | ||||
| import androidx.compose.ui.Alignment | ||||
| import androidx.compose.ui.Modifier | ||||
| import androidx.compose.ui.graphics.Color | ||||
| import dev.inmo.kmppscriptbuilder.desktop.utils.* | ||||
| import dev.inmo.kmppscriptbuilder.desktop.views.* | ||||
| import androidx.compose.ui.window.Window | ||||
| import androidx.compose.ui.window.application | ||||
| import dev.inmo.kmppscriptbuilder.desktop.utils.init | ||||
| import dev.inmo.kmppscriptbuilder.desktop.utils.loadConfigFile | ||||
| import dev.inmo.kmppscriptbuilder.desktop.views.BuilderView | ||||
| import java.io.File | ||||
|  | ||||
| //private val uncaughtExceptionsBC = BroadcastChannel<DefaultErrorHandler.ErrorEvent>(Channel.CONFLATED) | ||||
| //val uncaughtExceptionsFlow: Flow<DefaultErrorHandler.ErrorEvent> = uncaughtExceptionsBC.asFlow() | ||||
|  | ||||
| fun main(args: Array<String>) = Window(title = "Kotlin Multiplatform Publishing Builder") { | ||||
| fun main(args: Array<String>) = application { | ||||
|     Window(onCloseRequest = ::exitApplication, title = "Kotlin Multiplatform Publishing Builder") { | ||||
|         val builder = BuilderView() | ||||
|         MaterialTheme( | ||||
|             Colors( | ||||
| @@ -59,4 +63,5 @@ fun main(args: Array<String>) = Window(title = "Kotlin Multiplatform Publishing | ||||
|             val config = loadConfigFile(File(args.first())) | ||||
|             builder.config = config | ||||
|         } | ||||
|     } | ||||
| } | ||||
|   | ||||
| @@ -1,7 +1,6 @@ | ||||
| package dev.inmo.kmppscriptbuilder.desktop.utils | ||||
|  | ||||
| import java.awt.Desktop | ||||
| import java.lang.Exception | ||||
| import java.net.URI | ||||
|  | ||||
| fun openLink(link: String): Boolean { | ||||
|   | ||||
| @@ -6,18 +6,10 @@ import androidx.compose.foundation.layout.* | ||||
| import androidx.compose.material.* | ||||
| import androidx.compose.runtime.* | ||||
| import androidx.compose.ui.Modifier | ||||
| import androidx.compose.ui.graphics.asImageBitmap | ||||
| import androidx.compose.ui.platform.DesktopPlatform | ||||
| import androidx.compose.ui.res.loadSvgResource | ||||
| import androidx.compose.ui.res.svgResource | ||||
| import androidx.compose.ui.unit.Density | ||||
| import androidx.compose.ui.res.painterResource | ||||
| import androidx.compose.ui.unit.dp | ||||
| import dev.inmo.kmppscriptbuilder.core.models.Config | ||||
| import dev.inmo.kmppscriptbuilder.desktop.utils.* | ||||
| import dev.inmo.micro_utils.coroutines.safelyWithoutExceptions | ||||
| import java.awt.Desktop | ||||
| import java.lang.Exception | ||||
| import java.net.URL | ||||
|  | ||||
| class BuilderView : View() { | ||||
|     private val projectTypeView = ProjectTypeView() | ||||
| @@ -53,7 +45,7 @@ class BuilderView : View() { | ||||
|                             } | ||||
|                         ) { | ||||
|                             Image( | ||||
|                                 painter = svgResource("images/open_file.svg"), | ||||
|                                 painter = painterResource("images/open_file.svg"), | ||||
|                                 contentDescription = "Open file" | ||||
|                             ) | ||||
|                         } | ||||
| @@ -65,7 +57,7 @@ class BuilderView : View() { | ||||
|                                 } | ||||
|                             ) { | ||||
|                                 Image( | ||||
|                                     painter = svgResource("images/save_file.svg"), | ||||
|                                     painter = painterResource("images/save_file.svg"), | ||||
|                                     contentDescription = "Save file" | ||||
|                                 ) | ||||
|                             } | ||||
| @@ -78,7 +70,7 @@ class BuilderView : View() { | ||||
|                                 } | ||||
|                             ) { | ||||
|                                 Image( | ||||
|                                     painter = svgResource("images/export_gradle.svg"), | ||||
|                                     painter = painterResource("images/export_gradle.svg"), | ||||
|                                     contentDescription = "Export Gradle script" | ||||
|                                 ) | ||||
|                             } | ||||
| @@ -92,7 +84,7 @@ class BuilderView : View() { | ||||
|                             } | ||||
|                         ) { | ||||
|                             Image( | ||||
|                                 painter = svgResource("images/save_as.svg"), | ||||
|                                 painter = painterResource("images/save_as.svg"), | ||||
|                                 contentDescription = "Export Gradle script" | ||||
|                             ) | ||||
|                         } | ||||
|   | ||||
| @@ -2,7 +2,7 @@ package dev.inmo.kmppscriptbuilder.desktop.views | ||||
|  | ||||
| import androidx.compose.runtime.* | ||||
| import dev.inmo.kmppscriptbuilder.core.models.Developer | ||||
| import dev.inmo.kmppscriptbuilder.desktop.utils.* | ||||
| import dev.inmo.kmppscriptbuilder.desktop.utils.CommonTextField | ||||
|  | ||||
| class DeveloperState( | ||||
|     id: String = "", | ||||
|   | ||||
| @@ -53,7 +53,7 @@ class LicensesView: VerticalView("Licenses") { | ||||
|             licensesOffersToShow.clear() | ||||
|             if (licenseSearchFilter.isNotEmpty()) { | ||||
|                 licensesOffersToShow.addAll( | ||||
|                     availableLicensesState.filter { filterText.all { symbol -> symbol.toLowerCase() in it.title } } | ||||
|                     availableLicensesState.filter { filterText.all { symbol -> symbol.lowercaseChar() in it.title } } | ||||
|                 ) | ||||
|             } | ||||
|         } | ||||
|   | ||||
| @@ -1,11 +1,13 @@ | ||||
| package dev.inmo.kmppscriptbuilder.desktop.views | ||||
|  | ||||
| import androidx.compose.foundation.layout.* | ||||
| import androidx.compose.material.* | ||||
| import androidx.compose.runtime.* | ||||
| import androidx.compose.material.Button | ||||
| import androidx.compose.runtime.Composable | ||||
| import androidx.compose.runtime.mutableStateListOf | ||||
| import androidx.compose.ui.Modifier | ||||
| import androidx.compose.ui.unit.dp | ||||
| import dev.inmo.kmppscriptbuilder.desktop.utils.* | ||||
| import dev.inmo.kmppscriptbuilder.desktop.utils.CommonText | ||||
| import dev.inmo.kmppscriptbuilder.desktop.utils.VerticalView | ||||
|  | ||||
| abstract class ListView<T>(title: String) : VerticalView(title) { | ||||
|     protected val itemsList = mutableStateListOf<T>() | ||||
|   | ||||
| @@ -2,8 +2,7 @@ package dev.inmo.kmppscriptbuilder.desktop.views | ||||
|  | ||||
| import androidx.compose.foundation.layout.ColumnScope | ||||
| import androidx.compose.runtime.* | ||||
| import dev.inmo.kmppscriptbuilder.core.models.MavenConfig | ||||
| import dev.inmo.kmppscriptbuilder.core.models.SonatypeRepository | ||||
| import dev.inmo.kmppscriptbuilder.core.models.* | ||||
| import dev.inmo.kmppscriptbuilder.desktop.utils.* | ||||
|  | ||||
| class MavenInfoView : VerticalView("Project information") { | ||||
| @@ -11,31 +10,35 @@ class MavenInfoView : VerticalView("Project information") { | ||||
|     private var projectDescriptionProperty by mutableStateOf("") | ||||
|     private var projectUrlProperty by mutableStateOf("") | ||||
|     private var projectVcsUrlProperty by mutableStateOf("") | ||||
|     private var includeGpgSignProperty by mutableStateOf(true) | ||||
|     private var gpgSignProperty by mutableStateOf<GpgSigning>(GpgSigning.Disabled) | ||||
|     private var publishToMavenCentralProperty by mutableStateOf(false) | ||||
|     private val developersView = DevelopersView() | ||||
|     private val repositoriesView = RepositoriesView() | ||||
|  | ||||
|     var mavenConfig: MavenConfig | ||||
|         get() = MavenConfig( | ||||
|             projectNameProperty, | ||||
|             projectDescriptionProperty, | ||||
|             projectNameProperty.ifBlank { defaultProjectName }, | ||||
|             projectDescriptionProperty.ifBlank { defaultProjectDescription }, | ||||
|             projectUrlProperty, | ||||
|             projectVcsUrlProperty, | ||||
|             includeGpgSignProperty, | ||||
|             developersView.developers, | ||||
|             repositoriesView.repositories + if (publishToMavenCentralProperty) { | ||||
|                 listOf(SonatypeRepository) | ||||
|             } else { | ||||
|                 emptyList() | ||||
|             } | ||||
|             }, | ||||
|             gpgSignProperty | ||||
|         ) | ||||
|         set(value) { | ||||
|             projectNameProperty = value.name | ||||
|             projectDescriptionProperty = value.description | ||||
|             projectUrlProperty = value.url | ||||
|             projectVcsUrlProperty = value.vcsUrl | ||||
|             includeGpgSignProperty = value.includeGpgSigning | ||||
|             gpgSignProperty = if (value.includeGpgSigning) { | ||||
|                 GpgSigning.Enabled | ||||
|             } else { | ||||
|                 value.gpgSigning | ||||
|             } | ||||
|             publishToMavenCentralProperty = value.repositories.any { it == SonatypeRepository } | ||||
|             developersView.developers = value.developers | ||||
|             repositoriesView.repositories = value.repositories.filter { it != SonatypeRepository } | ||||
| @@ -60,11 +63,12 @@ class MavenInfoView : VerticalView("Project information") { | ||||
|             "Public project VCS URL (with .git)" | ||||
|         ) { projectVcsUrlProperty = it } | ||||
|  | ||||
|         SwitchWithLabel( | ||||
|             "Include GPG Signing", | ||||
|             includeGpgSignProperty, | ||||
|             placeSwitchAtTheStart = true | ||||
|         ) { includeGpgSignProperty = it } | ||||
|  | ||||
| //        SwitchWithLabel( | ||||
| //            "Include GPG Signing", | ||||
| //            includeGpgSignProperty, | ||||
| //            placeSwitchAtTheStart = true | ||||
| //        ) { includeGpgSignProperty = it } | ||||
|  | ||||
|         SwitchWithLabel( | ||||
|             "Include publication to MavenCentral", | ||||
|   | ||||
| @@ -2,7 +2,7 @@ package dev.inmo.kmppscriptbuilder.desktop.views | ||||
|  | ||||
| import androidx.compose.runtime.* | ||||
| import dev.inmo.kmppscriptbuilder.core.models.MavenPublishingRepository | ||||
| import dev.inmo.kmppscriptbuilder.desktop.utils.* | ||||
| import dev.inmo.kmppscriptbuilder.desktop.utils.CommonTextField | ||||
|  | ||||
| class RepositoryState( | ||||
|     name: String = "", | ||||
|   | ||||
| @@ -6,27 +6,27 @@ kotlin.incremental.js=true | ||||
| android.useAndroidX=true | ||||
| android.enableJetifier=true | ||||
|  | ||||
| kotlin_version=1.4.31 | ||||
| kotlin_coroutines_version=1.4.3 | ||||
| kotlin_serialisation_core_version=1.1.0 | ||||
| ktor_version=1.5.2 | ||||
| micro_utils_version=0.4.29 | ||||
| kotlin_version=1.6.10 | ||||
| kotlin_coroutines_version=1.6.0 | ||||
| kotlin_serialisation_core_version=1.3.2 | ||||
| ktor_version=1.6.7 | ||||
| micro_utils_version=0.9.0 | ||||
|  | ||||
| compose_version=0.3.2 | ||||
| compose_version=1.0.1 | ||||
|  | ||||
| # ANDROID | ||||
|  | ||||
| android_minSdkVersion=21 | ||||
| android_compileSdkVersion=30 | ||||
| android_buildToolsVersion=30.0.2 | ||||
| dexcount_version=2.0.0 | ||||
| android_compileSdkVersion=32 | ||||
| android_buildToolsVersion=32.0.0 | ||||
| dexcount_version=3.0.1 | ||||
| junit_version=4.12 | ||||
| test_ext_junit_version=1.1.2 | ||||
| espresso_core=3.3.0 | ||||
|  | ||||
| # Dokka | ||||
|  | ||||
| dokka_version=1.4.20 | ||||
| dokka_version=1.6.0 | ||||
|  | ||||
| # Project data | ||||
|  | ||||
|   | ||||
							
								
								
									
										2
									
								
								gradle/wrapper/gradle-wrapper.properties
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								gradle/wrapper/gradle-wrapper.properties
									
									
									
									
										vendored
									
									
								
							| @@ -2,4 +2,4 @@ distributionBase=GRADLE_USER_HOME | ||||
| distributionPath=wrapper/dists | ||||
| zipStoreBase=GRADLE_USER_HOME | ||||
| zipStorePath=wrapper/dists | ||||
| distributionUrl=https\://services.gradle.org/distributions/gradle-6.8-bin.zip | ||||
| distributionUrl=https\://services.gradle.org/distributions/gradle-7.3.3-bin.zip | ||||
|   | ||||
| @@ -48,7 +48,7 @@ class LicensesView( | ||||
|                     emptyList() | ||||
|                 } else { | ||||
|                     licensesTemplates.filter { | ||||
|                         val lowercasedTitle = it.title.toLowerCase() | ||||
|                         val lowercasedTitle = it.title.lowercase() | ||||
|                         lowercased.all { it in lowercasedTitle } | ||||
|                     } | ||||
|                 } | ||||
| @@ -57,12 +57,12 @@ class LicensesView( | ||||
|         } | ||||
|         private val searchElement = rootElement.createTextField("Quick add", "Type some license name part to find it").apply { | ||||
|             oninput = { | ||||
|                 changeActor.offer(Unit) | ||||
|                 changeActor.trySend(Unit) | ||||
|                 false | ||||
|             } | ||||
|         } | ||||
|         private var searchString: String | ||||
|             get() = searchElement.value.toLowerCase() | ||||
|             get() = searchElement.value.lowercase() | ||||
|             set(value) { | ||||
|                 searchElement.value = value | ||||
|             } | ||||
| @@ -71,7 +71,7 @@ class LicensesView( | ||||
|             createCommonButton(value.title).onclick = { | ||||
|                 searchString = "" | ||||
|                 licensesView.licenses += value | ||||
|                 changeActor.offer(Unit) | ||||
|                 changeActor.trySend(Unit) | ||||
|                 false | ||||
|             } | ||||
|         } | ||||
|   | ||||
| @@ -1,7 +1,7 @@ | ||||
| package dev.inmo.kmppscriptbuilder.web.views | ||||
|  | ||||
| import dev.inmo.kmppscriptbuilder.core.models.MavenConfig | ||||
| import dev.inmo.kmppscriptbuilder.core.models.SonatypeRepository | ||||
| import dev.inmo.kmppscriptbuilder.core.models.* | ||||
| import dev.inmo.kmppscriptbuilder.web.utils.ukActive | ||||
| import kotlinx.browser.document | ||||
| import org.w3c.dom.HTMLElement | ||||
| import org.w3c.dom.HTMLInputElement | ||||
| @@ -11,23 +11,51 @@ class MavenProjectInfoView : View { | ||||
|     private val descriptionElement = document.getElementById("projectDescriptionInput") as HTMLInputElement | ||||
|     private val urlElement = document.getElementById("projectUrlInput") as HTMLInputElement | ||||
|     private val vcsUrlElement = document.getElementById("projectVCSUrlInput") as HTMLInputElement | ||||
|     private val includeGpgElement = document.getElementById("includeGpgSignToggle") as HTMLInputElement | ||||
|     private val disableGpgSigningElement = document.getElementById("disableGpgSigning") as HTMLElement | ||||
|     private val optionalGpgSigningElement = document.getElementById("optionalGpgSigning") as HTMLElement | ||||
|     private val enableGpgSigningElement = document.getElementById("enableGpgSigning") as HTMLElement | ||||
|     private val includeMavenCentralElement = document.getElementById("includeMavenCentralTargetRepoToggle") as HTMLInputElement | ||||
|     private val developersView = DevelopersView(document.getElementById("developersListDiv") as HTMLElement) | ||||
|     private val repositoriesView = RepositoriesView(document.getElementById("repositoriesListDiv") as HTMLElement) | ||||
|  | ||||
|     private var gpgSignMode: GpgSigning = GpgSigning.Disabled | ||||
|         set(value) { | ||||
|             field = value | ||||
|             when (value) { | ||||
|                 GpgSigning.Enabled -> { | ||||
|                     enableGpgSigningElement.ukActive = true | ||||
|                     disableGpgSigningElement.ukActive = false | ||||
|                     optionalGpgSigningElement.ukActive = false | ||||
|                 } | ||||
|                 GpgSigning.Optional -> { | ||||
|                     enableGpgSigningElement.ukActive = false | ||||
|                     disableGpgSigningElement.ukActive = false | ||||
|                     optionalGpgSigningElement.ukActive = true | ||||
|                 } | ||||
|                 GpgSigning.Disabled -> { | ||||
|                     enableGpgSigningElement.ukActive = false | ||||
|                     disableGpgSigningElement.ukActive = true | ||||
|                     optionalGpgSigningElement.ukActive = false | ||||
|                 } | ||||
|             } | ||||
|         } | ||||
|  | ||||
|     var mavenConfig: MavenConfig | ||||
|         get() = MavenConfig( | ||||
|             nameElement.value, | ||||
|             descriptionElement.value, | ||||
|             nameElement.value.ifBlank { defaultProjectName }, | ||||
|             descriptionElement.value.ifBlank { defaultProjectDescription }, | ||||
|             urlElement.value, | ||||
|             vcsUrlElement.value, | ||||
|             includeGpgElement.checked, | ||||
|             developersView.developers, | ||||
|             repositoriesView.repositories + if (includeMavenCentralElement.checked) { | ||||
|                 listOf(SonatypeRepository) | ||||
|             } else { | ||||
|                 emptyList() | ||||
|             }, | ||||
|             when { | ||||
|                 optionalGpgSigningElement.ukActive -> GpgSigning.Optional | ||||
|                 enableGpgSigningElement.ukActive -> GpgSigning.Enabled | ||||
|                 else -> GpgSigning.Disabled | ||||
|             } | ||||
|         ) | ||||
|         set(value) { | ||||
| @@ -35,10 +63,20 @@ class MavenProjectInfoView : View { | ||||
|             descriptionElement.value = value.description | ||||
|             urlElement.value = value.url | ||||
|             vcsUrlElement.value = value.vcsUrl | ||||
|             includeGpgElement.checked = value.includeGpgSigning | ||||
|             gpgSignMode = if (value.includeGpgSigning) { | ||||
|                 GpgSigning.Enabled | ||||
|             } else { | ||||
|                 value.gpgSigning | ||||
|             } | ||||
|             developersView.developers = value.developers | ||||
|             val reposWithoutSonatype = value.repositories.filter { it != SonatypeRepository } | ||||
|             includeMavenCentralElement.checked = value.repositories.size != reposWithoutSonatype.size | ||||
|             repositoriesView.repositories = reposWithoutSonatype | ||||
|         } | ||||
|  | ||||
|     init { | ||||
|         enableGpgSigningElement.onclick = { gpgSignMode = GpgSigning.Enabled; Unit } | ||||
|         disableGpgSigningElement.onclick = { gpgSignMode = GpgSigning.Disabled; Unit } | ||||
|         optionalGpgSigningElement.onclick = { gpgSignMode = GpgSigning.Optional; Unit } | ||||
|     } | ||||
| } | ||||
| @@ -8,16 +8,18 @@ import org.w3c.dom.HTMLElement | ||||
| class ProjectTypeView : View { | ||||
|     private val mppProjectTypeElement = document.getElementById("mppProjectType") as HTMLElement | ||||
|     private val jvmProjectTypeElement = document.getElementById("jvmProjectType") as HTMLElement | ||||
|     private val jsProjectTypeElement = document.getElementById("jsProjectType") as HTMLElement | ||||
|  | ||||
|     var projectType: ProjectType | ||||
|         get() = if (jvmProjectTypeElement.ukActive) { | ||||
|             JVMProjectType | ||||
|         } else { | ||||
|             MultiplatformProjectType | ||||
|         get() = when { | ||||
|             jvmProjectTypeElement.ukActive -> JVMProjectType | ||||
|             jsProjectTypeElement.ukActive -> JSProjectType | ||||
|             else -> MultiplatformProjectType | ||||
|         } | ||||
|         set(value) { | ||||
|             mppProjectTypeElement.ukActive = value == MultiplatformProjectType | ||||
|             jvmProjectTypeElement.ukActive = value == JVMProjectType | ||||
|             jsProjectTypeElement.ukActive = value == JSProjectType | ||||
|         } | ||||
|  | ||||
|     init { | ||||
| @@ -29,5 +31,9 @@ class ProjectTypeView : View { | ||||
|             projectType = JVMProjectType | ||||
|             Unit | ||||
|         } | ||||
|         jsProjectTypeElement.onclick = { | ||||
|             projectType = JSProjectType | ||||
|             Unit | ||||
|         } | ||||
|     } | ||||
| } | ||||
| @@ -27,15 +27,11 @@ | ||||
|                 <ul class="uk-subnav uk-subnav-pill"> | ||||
|                     <li id="mppProjectType" class="uk-active"><a href="#">Multiplatform</a></li> | ||||
|                     <li id="jvmProjectType"><a href="#">JVM</a></li> | ||||
|                     <li id="jsProjectType"><a href="#">JS</a></li> | ||||
|                 </ul> | ||||
|             </div> | ||||
|             <legend class="uk-legend">Licenses</legend> | ||||
|             <div id="licensesListDiv" class="uk-padding-small"> | ||||
| <!--                <div class="uk-margin uk-width-1-1">--> | ||||
| <!--                    <input id="searchFilterInput" class="uk-input uk-width-expand" type="text" placeholder="License search filter">--> | ||||
| <!--                </div>--> | ||||
| <!--                <button class="uk-button uk-button-primary">Add empty license</button>--> | ||||
|             </div> | ||||
|             <div id="licensesListDiv" class="uk-padding-small"></div> | ||||
|  | ||||
|             <legend class="uk-legend">Project information</legend> | ||||
|  | ||||
| @@ -58,7 +54,15 @@ | ||||
|                 </div> | ||||
|  | ||||
|                 <div class="uk-margin"> | ||||
|                     <label><input id="includeGpgSignToggle" class="uk-checkbox" type="checkbox" checked> Include GPG Signing</label> | ||||
|                     <label>GPG Signing</label> | ||||
|  | ||||
|                     <div class="uk-padding-small"> | ||||
|                         <ul class="uk-subnav uk-subnav-pill"> | ||||
|                             <li id="disableGpgSigning" class="uk-active" uk-tooltip="title: Signing will not be added"><a href="#">Disabled</a></li> | ||||
|                             <li id="optionalGpgSigning" uk-tooltip="title: Signing will be added, but disabled in case of absence 'signatory.keyId'"><a href="#">Optional</a></li> | ||||
|                             <li id="enableGpgSigning" uk-tooltip="title: Signing will be always enabled"><a href="#">Enabled</a></li> | ||||
|                         </ul> | ||||
|                     </div> | ||||
|                 </div> | ||||
|                 <div class="uk-margin"> | ||||
|                     <label><input id="includeMavenCentralTargetRepoToggle" class="uk-checkbox" type="checkbox"> Include publication to MavenCentral</label> | ||||
|   | ||||
		Reference in New Issue
	
	Block a user