Gradle 如何使用kotlin前端插件设置package.json配置

Gradle 如何使用kotlin前端插件设置package.json配置,gradle,npm,webpack,kotlin,Gradle,Npm,Webpack,Kotlin,我希望自动生成的package.json以指向Kotlin生成的JavaScript文件的方式进行配置。这是我当前的gradle配置: apply plugin: 'kotlin-platform-js' apply from: "$project.rootDir/gradle/deploy.gradle" dependencies { expectedBy project(":") // Compile/implementati

我希望自动生成的package.json以指向Kotlin生成的JavaScript文件的方式进行配置。这是我当前的gradle配置:

apply plugin: 'kotlin-platform-js'
apply from: "$project.rootDir/gradle/deploy.gradle"


dependencies {
               expectedBy project(":")

               // Compile/implementation dependencies
               implementation "org.jetbrains.kotlin:kotlin-stdlib-js:$kotlin_version"
}

apply plugin: 'org.jetbrains.kotlin.frontend'

compileKotlin2Js {
                    kotlinOptions.metaInfo = true
                    kotlinOptions.sourceMap = true
                    kotlinOptions.moduleKind = 'commonjs'
}

kotlinFrontend {
                    sourceMaps = true

                    npm {
                           dependency("kotlin")
                           replaceVersion("kotlin-js-library", "1.1.0")
                    }

                    define "PRODUCTION", true

                    webpackBundle {
                                      bundleName = "${project.name}"
                                      sourceMapEnabled = true
                    }
}
这将输出一个位于$project.builDir.path/classes/nain中的myProject.js文件,我希望它能反映在生成的package.json文件中。但是输出的package.json文件(位于项目的构建目录中)如下所示:

{
    "name": "myProject",
    "version": "1.2.0-10-SNAPSHOT",
    "description": "simple description",
    "main": "myProject",
    "dependencies": {
         "kotlin": "*"
    },
    "devDependencies": {
        "webpack": "*",
        "webpack-dev-server": "*",
        "source-map-loader": "*",
        "karma": "*",
        "qunitjs": "1.23.1",
        "karma-qunit": "*",
        "karma-sourcemap-loader": "*",
        "karma-phantomjs-launcher": "*",
        "phantomjs-prebuilt": "*",
        "karma-webpack": "*"
    }
}

问题在于,package.json中的“main”属性没有指向位于classes/main/myProject.js中的bundle文件。我试图查看文档,找到如何将主属性设置为特定目录和js文件,但找不到它。我只能通过在gradle文件的WebPackageBundle部分中设置bundleName属性来更改名称。提前谢谢你的帮助

所以我找到了一个解决办法,可以使用gradle发布到npm。我在代码中添加了以下内容:

apply plugin: "com.moowork.node"

//Must copy the output javascript file
//to the location that the package.json expects it to be
//This is semi-workaround since I have not found a way to
//configure the outputted package.json file
task copyJSFile(type: Copy){

    from "$project.buildDir.path/classes/main/"
    into "${project.buildDir}"
    include "*.js"
}

//We publish our project to npm
task npmPublish(dependsOn: copyJSFile, type: NpmTask) {
    description = "publishes the project to npm"
    workingDir = file("${project.buildDir}")
    args = ['publish']
}

这样做的目的是将输出的JavaScript生成的文件复制到调用npmPublish gradle任务时配置package.json的位置。

我尝试在gradle文件中设置compileKotlin2Js,如下所示:compileKotlin2Js{kotlinOptions.metaInfo=true kotlinOptions.sourceMap=true kotlinOptions.moduleKind='commonjs'kotlinOptions.outputFile=“$project.buildDir.path/${project.name}.js”}但它会导致错误:配置对象无效。已使用与API架构不匹配的配置对象初始化了Web包。-配置。解析。模块[0]不应为空