jormungandr-bite/src/client/app/mobile/api/post.ts

44 lines
1 KiB
TypeScript
Raw Normal View History

2018-02-21 10:15:46 -07:00
import PostForm from '../views/components/post-form.vue';
2018-02-21 10:22:10 -07:00
//import RepostForm from '../views/components/repost-form.vue';
2018-04-01 21:58:53 -06:00
import getPostSummary from '../../../../get-post-summary';
2018-02-21 10:15:46 -07:00
2018-02-21 10:22:10 -07:00
export default (os) => (opts) => {
2018-02-21 10:15:46 -07:00
const o = opts || {};
2018-02-21 10:00:30 -07:00
2018-02-21 10:15:46 -07:00
if (o.repost) {
2018-02-21 10:22:10 -07:00
/*const vm = new RepostForm({
2018-02-21 10:15:46 -07:00
propsData: {
repost: o.repost
}
}).$mount();
vm.$once('cancel', recover);
vm.$once('post', recover);
2018-02-21 10:22:10 -07:00
document.body.appendChild(vm.$el);*/
const text = window.prompt(`${getPostSummary(o.repost)}」をRepost`);
if (text == null) return;
os.api('posts/create', {
2018-03-28 23:48:47 -06:00
repostId: o.repost.id,
2018-02-21 10:22:10 -07:00
text: text == '' ? undefined : text
});
2018-02-21 10:15:46 -07:00
} else {
2018-02-21 10:22:10 -07:00
const app = document.getElementById('app');
app.style.display = 'none';
function recover() {
app.style.display = 'block';
}
2018-02-21 10:15:46 -07:00
const vm = new PostForm({
2018-02-27 09:13:42 -07:00
parent: os.app,
2018-02-21 10:15:46 -07:00
propsData: {
reply: o.reply
}
}).$mount();
vm.$once('cancel', recover);
vm.$once('post', recover);
document.body.appendChild(vm.$el);
2018-02-22 13:43:19 -07:00
(vm as any).focus();
2018-02-21 10:15:46 -07:00
}
2018-02-21 10:22:10 -07:00
};