Chart export & import

This commit is contained in:
cuigh 2018-04-08 18:40:15 +08:00
parent 8be8cd382c
commit 7d1bf77be3
7 changed files with 79 additions and 6 deletions

View File

@ -1644,7 +1644,10 @@ var Swirl;
constructor() { constructor() {
this.$charts = $("#div-charts").children(); this.$charts = $("#div-charts").children();
this.fb = new FilterBox("#txt-query", this.filterCharts.bind(this)); this.fb = new FilterBox("#txt-query", this.filterCharts.bind(this));
Dispatcher.bind("#div-charts").on("delete-chart", this.deleteChart.bind(this)); $("#btn-import").click(this.importChart);
Dispatcher.bind("#div-charts")
.on("export-chart", this.exportChart.bind(this))
.on("delete-chart", this.deleteChart.bind(this));
} }
deleteChart(e) { deleteChart(e) {
let $container = $(e.target).closest("div.column"); let $container = $(e.target).closest("div.column");
@ -1677,6 +1680,31 @@ var Swirl;
$elem.hide(); $elem.hide();
}); });
} }
exportChart(e) {
let $container = $(e.target).closest("div.column");
let name = $container.data("name");
$ajax.get(name + "/detail").text(r => {
Modal.alert(`<textarea class="textarea" rows="8" readonly>${r}</textarea>`, "Export chart");
});
}
importChart(e) {
Modal.confirm(`<textarea class="textarea" rows="8"></textarea>`, "Import chart", (dlg, e) => {
try {
let chart = JSON.parse(dlg.find('textarea').val());
$ajax.post("new", chart).trigger(e.target).json(r => {
if (r.success) {
location.reload();
}
else {
dlg.error(r.message);
}
});
}
catch (e) {
dlg.error(e);
}
});
}
} }
Metric.ListPage = ListPage; Metric.ListPage = ListPage;
})(Metric = Swirl.Metric || (Swirl.Metric = {})); })(Metric = Swirl.Metric || (Swirl.Metric = {}));

File diff suppressed because one or more lines are too long

View File

@ -14,7 +14,10 @@ namespace Swirl.Metric {
this.fb = new FilterBox("#txt-query", this.filterCharts.bind(this)); this.fb = new FilterBox("#txt-query", this.filterCharts.bind(this));
// bind events // bind events
Dispatcher.bind("#div-charts").on("delete-chart", this.deleteChart.bind(this)); $("#btn-import").click(this.importChart);
Dispatcher.bind("#div-charts")
.on("export-chart", this.exportChart.bind(this))
.on("delete-chart", this.deleteChart.bind(this));
} }
private deleteChart(e: JQueryEventObject) { private deleteChart(e: JQueryEventObject) {
@ -24,7 +27,7 @@ namespace Swirl.Metric {
$ajax.post(name + "/delete").trigger(e.target).json<AjaxResult>(r => { $ajax.post(name + "/delete").trigger(e.target).json<AjaxResult>(r => {
$container.remove(); $container.remove();
dlg.close(); dlg.close();
}) });
}); });
} }
@ -51,5 +54,30 @@ namespace Swirl.Metric {
$elem.hide(); $elem.hide();
}) })
} }
private exportChart(e: JQueryEventObject) {
let $container = $(e.target).closest("div.column");
let name = $container.data("name");
$ajax.get(name + "/detail").text(r => {
Modal.alert(`<textarea class="textarea" rows="8" readonly>${r}</textarea>`, "Export chart");
});
}
private importChart(e: JQueryEventObject) {
Modal.confirm(`<textarea class="textarea" rows="8"></textarea>`, "Import chart", (dlg, e) => {
try {
let chart = JSON.parse(dlg.find('textarea').val());
$ajax.post("new", chart).trigger(e.target).json<AjaxResult>(r => {
if (r.success) {
location.reload();
} else {
dlg.error(r.message);
}
});
} catch (e) {
dlg.error(e);
}
});
}
} }
} }

View File

@ -22,6 +22,7 @@ button.scale: Scale
button.rollback: Rollback button.rollback: Rollback
button.previous: Previous button.previous: Previous
button.next: Next button.next: Next
button.import: Import
# field # field
field.name: Name field.name: Name

View File

@ -22,6 +22,7 @@ button.scale: 调整
button.rollback: 回退 button.rollback: 回退
button.previous: 前一页 button.previous: 前一页
button.next: 后一页 button.next: 后一页
button.import: 导入
# field # field
field.name: 名称 field.name: 名称

View File

@ -18,6 +18,7 @@ type ChartController struct {
Query web.HandlerFunc `path:"/query" name:"chart.query" authorize:"?" desc:"chart query"` Query web.HandlerFunc `path:"/query" name:"chart.query" authorize:"?" desc:"chart query"`
New web.HandlerFunc `path:"/new" name:"chart.new" authorize:"!" desc:"new chart page"` New web.HandlerFunc `path:"/new" name:"chart.new" authorize:"!" desc:"new chart page"`
Create web.HandlerFunc `path:"/new" method:"post" name:"chart.create" authorize:"!" desc:"create chart"` Create web.HandlerFunc `path:"/new" method:"post" name:"chart.create" authorize:"!" desc:"create chart"`
Detail web.HandlerFunc `path:"/:name/detail" name:"chart.detail" authorize:"?" desc:"chart detail"`
Edit web.HandlerFunc `path:"/:name/edit" name:"chart.edit" authorize:"!" desc:"edit chart page"` Edit web.HandlerFunc `path:"/:name/edit" name:"chart.edit" authorize:"!" desc:"edit chart page"`
Delete web.HandlerFunc `path:"/:name/delete" method:"post" name:"chart.delete" authorize:"!" desc:"delete chart"` Delete web.HandlerFunc `path:"/:name/delete" method:"post" name:"chart.delete" authorize:"!" desc:"delete chart"`
Update web.HandlerFunc `path:"/:name/edit" method:"post" name:"chart.update" authorize:"!" desc:"update chart"` Update web.HandlerFunc `path:"/:name/edit" method:"post" name:"chart.update" authorize:"!" desc:"update chart"`
@ -32,6 +33,7 @@ func Chart() (c *ChartController) {
Query: chartQuery, Query: chartQuery,
New: chartNew, New: chartNew,
Create: chartCreate, Create: chartCreate,
Detail: chartDetail,
Edit: chartEdit, Edit: chartEdit,
Update: chartUpdate, Update: chartUpdate,
Delete: chartDelete, Delete: chartDelete,
@ -50,6 +52,16 @@ func chartList(ctx web.Context) error {
return ctx.Render("system/chart/list", m) return ctx.Render("system/chart/list", m)
} }
func chartDetail(ctx web.Context) error {
name := ctx.P("name")
chart, err := biz.Chart.Get(name)
if err != nil {
return err
}
return ctx.JSON(chart, " ")
}
func chartQuery(ctx web.Context) error { func chartQuery(ctx web.Context) error {
charts, err := biz.Chart.List() charts, err := biz.Chart.List()
if err != nil { if err != nil {

View File

@ -29,6 +29,9 @@
<p class="level-item"> <p class="level-item">
<a href="new" class="button is-success"><span class="icon"><i class="fas fa-plus"></i></span><span>{{ i18n("button.new") }}</span></a> <a href="new" class="button is-success"><span class="icon"><i class="fas fa-plus"></i></span><span>{{ i18n("button.new") }}</span></a>
</p> </p>
<p class="level-item">
<button id="btn-import" class="button is-info"><span class="icon"><i class="fas fa-level-down-alt"></i></span><span>{{ i18n("button.import") }}</span></button>
</p>
</div> </div>
</nav> </nav>
<div id="div-charts" class="columns is-multiline"> <div id="div-charts" class="columns is-multiline">
@ -70,7 +73,7 @@
</article> </article>
</div> </div>
<footer class="card-footer"> <footer class="card-footer">
{*<a class="card-footer-item">View</a>*} <a data-action="export-chart" class="card-footer-item">Export</a>
<a href="{{ .Name }}/edit" class="card-footer-item">Edit</a> <a href="{{ .Name }}/edit" class="card-footer-item">Edit</a>
<a data-action="delete-chart" class="card-footer-item">Delete</a> <a data-action="delete-chart" class="card-footer-item">Delete</a>
</footer> </footer>