Создание приложения Kotlin React с использованием gradle - PullRequest
0 голосов
/ 25 мая 2018

Я с нетерпением ждал, как создать приложение kotlin-реагировать на приложение с помощью gradle (мне известен инструмент CLI create-kotlin-реагировать-приложение, в котором не используется radle), и я не смог получить никакогоисточники, чтобы указать мне до конца.Я наткнулся на плагин внешнего интерфейса kotlin (он работает) и плагин npm и webpack, но я не смог настроить их для запуска / создания моего проекта kotlin-реагировать.Я не специалист по настройке веб-пакетов, так что мне, вероятно, еще сложнее.

Начальные намерения

Я намерен создать мультиплатформенный проект (да, Kotlin Experiental упакован в IntelliJ)

Альтернативный подход

когда я потерпел неудачу, я предпочитаю использовать этот подход.

  1. Напишите мой код, используя мультиплатформенный плагин kotlin
  2. Скомпилируйте его в банку
  3. Добавить его как библиотеку в приложение create-реагировать-kotlin-, которое я создал бы
  4. Запустить и ждать, пока не произойдет волшебство (оно не работает) Оказывается, что-то вроде предварительно настроенного веб-пакетане компилировался, потому что не был доступен во время компиляции.но IDE работала хорошо и даже предоставила код дополнения

Может кто-нибудь указать мне направление?

1 Ответ

0 голосов
/ 14 июня 2018

Создание приложения реакции с использованием gradle легко при использовании плагина внешнего интерфейса kotlin.В IntelliJ выполните следующие действия:

Новый модуль> gradle> kotlin (Javascript)> [next, next, next ... finish]

Вам нужно будет настроить gradle ofcourse (в зависимости от того, каквам это нравится).

Я настроил свой, как показано ниже: -

buildscript {
    ext.kotlin_version = '1.2.41'
    ext.kotlinx_html_version = "0.6.4"
    ext.kotlin_frontend_version = "0.0.30"
    ext.react_version = "16.4.0-pre.31-kotlin-$kotlin_version"
    ext.react_dom_version = "16.4.0-pre.31-kotlin-$kotlin_version"
    repositories {
        mavenCentral()
        maven {
            url "https://dl.bintray.com/kotlin/kotlin-eap"
        }
    }
    dependencies {
        classpath "org.jetbrains.kotlin:kotlin-gradle-plugin:$kotlin_version"
        classpath "org.jetbrains.kotlin:kotlin-frontend-plugin:$kotlin_frontend_version"
    }
}
apply plugin: 'org.jetbrains.kotlin.frontend'
apply plugin: 'kotlin2js'
sourceCompatibility = 1.8
repositories {
    mavenLocal()
    mavenCentral()
    jcenter()
    maven { url "http://dl.bintray.com/kotlin/kotlin-dev" }
    maven { url "http://dl.bintray.com/kotlinx/kotlinx" }
    maven { url "http://dl.bintray.com/kotlin/kotlin-js-wrappers" }
}
dependencies {
    compile "org.jetbrains.kotlin:kotlin-stdlib-js:$kotlin_version"
    compile "org.jetbrains.kotlinx:kotlinx-html-js:$kotlinx_html_version"
    compile "org.jetbrains:kotlin-react:$react_version"
    compile "org.jetbrains:kotlin-react-dom:$react_dom_version"
}
kotlinFrontend {
    npm {
        dependency "style-loader" // production dependency
        dependency "react"
        dependency "react-dom"
        dependency "kotlin"
        dependency "@jetbrains/kotlin-extensions"
        dependency "@jetbrains/kotlin-react"
    }
    webpackBundle {
        bundleName = "main"
        sourceMapEnabled = false   // enable/disable source maps
        contentPath = file("${projectDir}/public") // a file that represents a directory to be served by dev server)
        publicPath = "/"  // web prefix
        host = "localhost" // dev server host
        port = 8088   // dev server port
        stats = "errors-only"  // log level
    }
}
task copyDocs(type: Copy) {
    println ":md-react:copyDocs: Copying to public directory"
    from("${projectDir}/build/bundle") {
        include "**/*.js"
        include "*.js"
    }
    into "${projectDir}/public/static"
    println ":md-react:copyDocs: Done copying"
}
task assembleWeb(type: Sync) {
    configurations.compile.each { File file ->
        from(zipTree(file.absolutePath), {
            includeEmptyDirs = false
            include { fileTreeElement ->
                def path = fileTreeElement.path
                (path.endsWith(".js") || path.endsWith(".map")) && (path.startsWith("META-INF/resources/") ||
                        !path.startsWith("META-INF/"))
            }
        })
    }
    from compileKotlin2Js.destinationDir
    into "${projectDir}/build/classes/main"
    dependsOn classes
}
//run.dependsOn copyDocs
assemble.dependsOn assembleWeb
copyDocs.dependsOn bundle
//assemble.finalizedBy(copyDocs)
compileKotlin2Js {
    kotlinOptions.outputFile = "${projectDir}/build/classes/main/web.js"
    kotlinOptions.moduleKind = "umd"
    kotlinOptions.sourceMap = true
}

Надеюсь, это вам поможет.

Счастливого взлома

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...