mirror of
https://github.com/discourse/discourse.git
synced 2024-11-22 09:12:45 +08:00
DEV: Load @json-editor/json-editor
using webpack async import (#27773)
This commit is contained in:
parent
270a0d9e0f
commit
ce3d91f422
1
.github/dependabot.yml
vendored
1
.github/dependabot.yml
vendored
|
@ -60,7 +60,6 @@ updates:
|
||||||
open-pull-requests-limit: 20
|
open-pull-requests-limit: 20
|
||||||
versioning-strategy: increase
|
versioning-strategy: increase
|
||||||
ignore: # These are all vendored so need to be updated manually. See lib/tasks/javascript.rake
|
ignore: # These are all vendored so need to be updated manually. See lib/tasks/javascript.rake
|
||||||
- dependency-name: "@json-editor/json-editor"
|
|
||||||
- dependency-name: "chart.js"
|
- dependency-name: "chart.js"
|
||||||
- dependency-name: "chartjs-plugin-datalabels"
|
- dependency-name: "chartjs-plugin-datalabels"
|
||||||
- dependency-name: "magnific-popup"
|
- dependency-name: "magnific-popup"
|
||||||
|
|
|
@ -1,10 +1,10 @@
|
||||||
import Component from "@glimmer/component";
|
import Component from "@glimmer/component";
|
||||||
import { tracked } from "@glimmer/tracking";
|
import { tracked } from "@glimmer/tracking";
|
||||||
import { action } from "@ember/object";
|
import { action } from "@ember/object";
|
||||||
|
import { waitForPromise } from "@ember/test-waiters";
|
||||||
import { create } from "virtual-dom";
|
import { create } from "virtual-dom";
|
||||||
import loadScript from "discourse/lib/load-script";
|
import { isTesting } from "discourse-common/config/environment";
|
||||||
import { iconNode } from "discourse-common/lib/icon-library";
|
import { iconNode } from "discourse-common/lib/icon-library";
|
||||||
import { afterRender } from "discourse-common/utils/decorators";
|
|
||||||
|
|
||||||
export default class JsonSchemaEditorModal extends Component {
|
export default class JsonSchemaEditorModal extends Component {
|
||||||
@tracked editor = null;
|
@tracked editor = null;
|
||||||
|
@ -16,13 +16,6 @@ export default class JsonSchemaEditorModal extends Component {
|
||||||
return this.args.model.settingName.replace(/\_/g, " ");
|
return this.args.model.settingName.replace(/\_/g, " ");
|
||||||
}
|
}
|
||||||
|
|
||||||
@action
|
|
||||||
buildJsonEditor(editor) {
|
|
||||||
loadScript("/javascripts/jsoneditor.js").then(
|
|
||||||
this._loadEditor.bind(this, editor)
|
|
||||||
);
|
|
||||||
}
|
|
||||||
|
|
||||||
@action
|
@action
|
||||||
teardownJsonEditor() {
|
teardownJsonEditor() {
|
||||||
this.editor?.destroy();
|
this.editor?.destroy();
|
||||||
|
@ -42,9 +35,13 @@ export default class JsonSchemaEditorModal extends Component {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@afterRender
|
@action
|
||||||
_loadEditor(editor) {
|
async buildJsonEditor(element) {
|
||||||
let { JSONEditor } = window;
|
const promise = await import("@json-editor/json-editor");
|
||||||
|
if (isTesting()) {
|
||||||
|
waitForPromise(promise);
|
||||||
|
}
|
||||||
|
const { JSONEditor } = await promise;
|
||||||
|
|
||||||
JSONEditor.defaults.options.theme = "barebones";
|
JSONEditor.defaults.options.theme = "barebones";
|
||||||
JSONEditor.defaults.iconlibs = {
|
JSONEditor.defaults.iconlibs = {
|
||||||
|
@ -52,7 +49,7 @@ export default class JsonSchemaEditorModal extends Component {
|
||||||
};
|
};
|
||||||
JSONEditor.defaults.options.iconlib = "discourseIcons";
|
JSONEditor.defaults.options.iconlib = "discourseIcons";
|
||||||
|
|
||||||
this.editor = new JSONEditor(editor, {
|
this.editor = new JSONEditor(element, {
|
||||||
schema: this.args.model.jsonSchema,
|
schema: this.args.model.jsonSchema,
|
||||||
disable_array_delete_all_rows: true,
|
disable_array_delete_all_rows: true,
|
||||||
disable_array_delete_last_row: true,
|
disable_array_delete_last_row: true,
|
||||||
|
|
|
@ -20,6 +20,7 @@
|
||||||
"@faker-js/faker": "^8.4.1",
|
"@faker-js/faker": "^8.4.1",
|
||||||
"@glimmer/syntax": "^0.92.0",
|
"@glimmer/syntax": "^0.92.0",
|
||||||
"@highlightjs/cdn-assets": "^11.10.0",
|
"@highlightjs/cdn-assets": "^11.10.0",
|
||||||
|
"@json-editor/json-editor": "2.10.0",
|
||||||
"@messageformat/core": "^3.3.0",
|
"@messageformat/core": "^3.3.0",
|
||||||
"@messageformat/runtime": "^3.0.1",
|
"@messageformat/runtime": "^3.0.1",
|
||||||
"ace-builds": "^1.35.2",
|
"ace-builds": "^1.35.2",
|
||||||
|
|
|
@ -65,11 +65,6 @@ end
|
||||||
|
|
||||||
def dependencies
|
def dependencies
|
||||||
[
|
[
|
||||||
{
|
|
||||||
source: "@json-editor/json-editor/dist/jsoneditor.js",
|
|
||||||
package_name: "@json-editor/json-editor",
|
|
||||||
public: true,
|
|
||||||
},
|
|
||||||
{ source: "chart.js/dist/chart.min.js", public: true },
|
{ source: "chart.js/dist/chart.min.js", public: true },
|
||||||
{ source: "chartjs-plugin-datalabels/dist/chartjs-plugin-datalabels.min.js", public: true },
|
{ source: "chartjs-plugin-datalabels/dist/chartjs-plugin-datalabels.min.js", public: true },
|
||||||
{ source: "magnific-popup/dist/jquery.magnific-popup.min.js", public: true },
|
{ source: "magnific-popup/dist/jquery.magnific-popup.min.js", public: true },
|
||||||
|
|
|
@ -12,7 +12,6 @@
|
||||||
"@glint/environment-ember-loose": "^1.4.0",
|
"@glint/environment-ember-loose": "^1.4.0",
|
||||||
"@glint/environment-ember-template-imports": "^1.4.0",
|
"@glint/environment-ember-template-imports": "^1.4.0",
|
||||||
"@glint/template": "^1.4.0",
|
"@glint/template": "^1.4.0",
|
||||||
"@json-editor/json-editor": "2.10.0",
|
|
||||||
"@mixer/parallel-prettier": "^2.0.3",
|
"@mixer/parallel-prettier": "^2.0.3",
|
||||||
"chart.js": "3.5.1",
|
"chart.js": "3.5.1",
|
||||||
"chartjs-plugin-datalabels": "2.2.0",
|
"chartjs-plugin-datalabels": "2.2.0",
|
||||||
|
|
File diff suppressed because one or more lines are too long
Loading…
Reference in New Issue
Block a user