Initial changes to create a campaign
This commit is contained in:
2
package-lock.json
generated
2
package-lock.json
generated
@@ -24,7 +24,7 @@
|
||||
}
|
||||
},
|
||||
"../mantra-db-models": {
|
||||
"version": "0.0.6.3",
|
||||
"version": "0.0.7",
|
||||
"license": "ISC",
|
||||
"dependencies": {
|
||||
"bcrypt": "^5.0.1",
|
||||
|
||||
@@ -8,8 +8,15 @@ module.exports = function (options) {
|
||||
.get(function(request, response, next) {
|
||||
response.display("campaigns", {
|
||||
user: request.user,
|
||||
pageTitle: "Library - Mantra"
|
||||
pageTitle: "Campaign - Mantra"
|
||||
})
|
||||
})
|
||||
|
||||
router.route('/create')
|
||||
.post(function(request, response, next) {
|
||||
console.log(request.body)
|
||||
next()
|
||||
})
|
||||
|
||||
return router;
|
||||
};
|
||||
@@ -317,5 +317,76 @@ module.exports = function (options) {
|
||||
next(error)
|
||||
})
|
||||
})
|
||||
|
||||
router.route('/:id/campaign')
|
||||
.get(function(request, response, next) {
|
||||
db.TranslationEntryVersion.findByPk(request.params.id, {
|
||||
include: [
|
||||
{
|
||||
association: db.TranslationEntryVersion.TranslationEntryVersionCampaigns,
|
||||
required: true,
|
||||
include: [
|
||||
{
|
||||
association: db.TranslationEntryVersionCampaign.Campaign,
|
||||
required: true
|
||||
}
|
||||
]
|
||||
}
|
||||
]
|
||||
}).then(translationEntryVersion => {
|
||||
if (translationEntryVersion) {
|
||||
if (translationEntryVersion.translationEntryVersionCampaings.length == 1) {
|
||||
response.redirect(`/campaigns/${translationEntryVersion.translationEntryVersionCampaings[0].campaignId}`)
|
||||
} else {
|
||||
// TODO: Display translation entry campaign...
|
||||
next()
|
||||
}
|
||||
} else {
|
||||
response.redirect(`/translate/${request.params.id}/campaign/create`)
|
||||
}
|
||||
})
|
||||
})
|
||||
|
||||
router.route('/:id/campaign/create')
|
||||
.get(function(request, response, next) {
|
||||
db.TranslationEntryVersion.findByPk(request.params.id, {
|
||||
include: [
|
||||
{
|
||||
association: db.TranslationEntryVersion.EntryVersion,
|
||||
include: [
|
||||
{
|
||||
association: db.EntryVersion.Entry
|
||||
}
|
||||
]
|
||||
},
|
||||
{
|
||||
association: db.TranslationEntryVersion.TranslationEntryVersionCampaigns,
|
||||
required: false,
|
||||
include: [
|
||||
{
|
||||
association: db.TranslationEntryVersionCampaign.Campaign,
|
||||
required: false
|
||||
}
|
||||
]
|
||||
}
|
||||
]
|
||||
}).then(translationEntryVersion => {
|
||||
if (translationEntryVersion) {
|
||||
response.display("campaign-form", {
|
||||
user: request.user,
|
||||
pageTitle: "Campaign - Mantra",
|
||||
campaign: {
|
||||
name: `Campaign for ${translationEntryVersion.name} translation of ${translationEntryVersion.entryVersion.entry.name}`
|
||||
},
|
||||
translationEntryVersions: [translationEntryVersion]
|
||||
})
|
||||
} else {
|
||||
next()
|
||||
}
|
||||
}).catch(error => {
|
||||
next(error)
|
||||
})
|
||||
})
|
||||
|
||||
return router;
|
||||
};
|
||||
@@ -266,6 +266,35 @@ module.exports = function (options) {
|
||||
next(error)
|
||||
})
|
||||
})
|
||||
|
||||
router.route('/:id/campaign/create')
|
||||
.get(function(request, response, next) {
|
||||
db.EntryVersion.findByPk(request.params.id, {
|
||||
include: [
|
||||
{
|
||||
association: db.EntryVersion.Entry,
|
||||
},
|
||||
{
|
||||
association: db.EntryVersion.TranslationEntryVersions
|
||||
}
|
||||
]
|
||||
}).then(entryVersion => {
|
||||
if (entryVersion) {
|
||||
response.display("campaign-form", {
|
||||
user: request.user,
|
||||
pageTitle: "Campaign - Mantra",
|
||||
campaign: {
|
||||
name: `Campaign for ${entryVersion.translationEntryVersions.length} translations of ${entryVersion.entry.name}`
|
||||
},
|
||||
translationEntryVersions: entryVersion.translationEntryVersions
|
||||
})
|
||||
} else {
|
||||
next()
|
||||
}
|
||||
}).catch(error => {
|
||||
next(error)
|
||||
})
|
||||
})
|
||||
|
||||
return router;
|
||||
};
|
||||
20
server/views/campaign-form.pug
Normal file
20
server/views/campaign-form.pug
Normal file
@@ -0,0 +1,20 @@
|
||||
extend templates/layout.pug
|
||||
|
||||
block content
|
||||
.container
|
||||
.center
|
||||
h1 Create Campaign
|
||||
|
||||
.row
|
||||
.col.s12
|
||||
form.row(action=`/campaigns/create`, method="post")
|
||||
.col.s12.input-field
|
||||
input#name(type="text", name="name", value=campaign.name)
|
||||
label(for="name") Campaign Name
|
||||
each translationEntryVersion in translationEntryVersions
|
||||
input(type="hidden", name="translationEntryVersions", value=translationEntryVersion.id)
|
||||
.col.s12.input-field
|
||||
input(id=translationEntryVersion.id+"-satoshis",type="number", name="satoshis", placeholder="100000 satoshis", step=1, min=1, max=2100000000000000, required)
|
||||
label(for=translationEntryVersion.id+"-satoshis") Satoshi's required for the #{translationEntryVersion.name} translation
|
||||
.col.s12
|
||||
button.btn.black(type="submit") create campaign
|
||||
@@ -9,6 +9,9 @@ block content
|
||||
.row
|
||||
.col.s12
|
||||
a.btn.black(href=`/fork/e/${entryVersion.id}`) fork
|
||||
.row
|
||||
.col.s12
|
||||
a.btn.black(href=`/v/${entryVersion.id}/campaign/create`) funding campaign
|
||||
.divider
|
||||
.row
|
||||
a.btn.black(href=`/v/${entryVersion.id}/chapters/add`) add chapter
|
||||
|
||||
@@ -24,4 +24,9 @@ block content
|
||||
.col.s12
|
||||
form(action=`/translate/${translationEntryVersion.id}/back`, method="post")
|
||||
button.btn.black(type="submit") back translate
|
||||
|
||||
|
||||
.row
|
||||
.col.s12
|
||||
a.btn.black(href=`/translate/${translationEntryVersion.id}/campaign`) funding campaign
|
||||
//- TODO: Give summary of chapters...
|
||||
|
||||
Reference in New Issue
Block a user