本文整理匯總了Python中tickets.models.TicketsEventMeta類的典型用法代碼示例。如果您正苦於以下問題:Python TicketsEventMeta類的具體用法?Python TicketsEventMeta怎麽用?Python TicketsEventMeta使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。
在下文中一共展示了TicketsEventMeta類的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。
示例1: setup_tickets
def setup_tickets(self):
from tickets.models import TicketsEventMeta, LimitGroup, Product
tickets_admin_group, = TicketsEventMeta.get_or_create_groups(self.event, ['admins'])
defaults = dict(
admin_group=tickets_admin_group,
due_days=14,
shipping_and_handling_cents=0,
reference_number_template="2016{:05d}",
contact_email='Mimicon <[email protected]>',
plain_contact_email='[email protected]',
ticket_free_text=u"Tämä on sähköinen lippusi Mimicon 2016 -tapahtumaan. Sähköinen lippu vaihdetaan rannekkeeseen\n"
u"lipunvaihtopisteessä saapuessasi tapahtumaan. Voit tulostaa tämän lipun tai näyttää sen\n"
u"älypuhelimen tai tablettitietokoneen näytöltä. Mikäli kumpikaan näistä ei ole mahdollista, ota ylös\n"
u"kunkin viivakoodin alla oleva neljästä tai viidestä sanasta koostuva sanakoodi ja ilmoita se\n"
u"lipunvaihtopisteessä.\n\n"
u"Tervetuloa Mimiconiin!",
front_page_text=u"<h2>Tervetuloa ostamaan pääsylippuja Mimicon 2016 -tapahtumaan!</h2>"
u"<p>Liput maksetaan suomalaisilla verkkopankkitunnuksilla heti tilauksen yhteydessä.</p>"
u"<p>Lue lisää tapahtumasta <a href='http://www.mimicon.fi'>Mimiconin kotisivuilta</a>.</p>",
print_logo_path = mkpath('static', 'images', 'mimicon2016_logo.png'),
print_logo_width_mm = 30,
print_logo_height_mm = 30,
)
if self.test:
t = now()
defaults.update(
ticket_sales_starts=t - timedelta(days=60),
ticket_sales_ends=t + timedelta(days=60),
)
else:
defaults.update(
ticket_sales_starts=datetime(2016, 1, 15, 16, 0, tzinfo=self.tz),
#ticket_sales_ends=datetime(2016, 1, 11, 18, 0, tzinfo=self.tz),
)
meta, unused = TicketsEventMeta.objects.get_or_create(event=self.event, defaults=defaults)
def limit_group(description, limit):
limit_group, unused = LimitGroup.objects.get_or_create(
event=self.event,
description=description,
defaults=dict(limit=limit),
)
return limit_group
def ordering():
ordering.counter += 10
return ordering.counter
ordering.counter = 0
for product_info in [
dict(
name=u'Mimicon 2016 -pääsylippu',
description=u'Lippu kattaa koko viikonlopun. Maksettuasi sinulle lähetetään PDF-lippu antamaasi sähköpostiin, jota vastaan saat rannekkeen tapahtuman ovelta.',
limit_groups=[
limit_group('Pääsyliput', 500),
],
price_cents=1600,
requires_shipping=False,
electronic_ticket=True,
available=True,
ordering=ordering(),
),
dict(
name=u'Lattiamajoituspaikka',
description=u'Lattiamajoituspaikka lauantain ja sunnuntain väliseksi yöksi. Tarvitset oman makuupussin ja -alustan. Lattiamajoituksesta ei lähetetä erillistä lippua, vaan lattiamajoitus toimii nimi listaan -periaatteella.',
limit_groups=[
limit_group('Lattiamajoitus', 80),
],
price_cents=500,
requires_shipping=False,
electronic_ticket=False,
available=True,
ordering=ordering(),
),
# dict(
# name=u'Lounaslippu',
# description=u'Tällä lipukkeella saat herkullisen lounaan ravintola Napostellasta kumpana tahansa tapahtumapäivänä. Lounasliput toimitetaan samalla PDF-lipulla pääsylippujesi kanssa.',
# limit_groups=[
# limit_group('Lounas', 100),
# ],
# price_cents=780,
# requires_shipping=False,
# electronic_ticket=True,
# available=False,
# ordering=ordering(),
# ),
]:
name = product_info.pop('name')
limit_groups = product_info.pop('limit_groups')
product, unused = Product.objects.get_or_create(
event=self.event,
name=name,
defaults=product_info
)
#.........這裏部分代碼省略.........
示例2: setup_tickets
def setup_tickets(self):
from tickets.models import TicketsEventMeta, LimitGroup, Product
tickets_admin_group, = TicketsEventMeta.get_or_create_groups(self.event, ['admins'])
defaults = dict(
admin_group=tickets_admin_group,
due_days=14,
shipping_and_handling_cents=120,
reference_number_template="2015{:05d}",
contact_email='Tracon Hitpoint -lipunmyynti <[email protected]>',
ticket_free_text="Tämä on sähköinen lippusi Tracon Hitpoint -tapahtumaan. Sähköinen lippu vaihdetaan rannekkeeseen\n"
"lipunvaihtopisteessä saapuessasi tapahtumaan. Voit tulostaa tämän lipun tai näyttää sen\n"
"älypuhelimen tai tablettitietokoneen näytöltä. Mikäli kumpikaan näistä ei ole mahdollista, ota ylös\n"
"kunkin viivakoodin alla oleva neljästä tai viidestä sanasta koostuva Kissakoodi ja ilmoita se\n"
"lipunvaihtopisteessä.\n\n"
"Tervetuloa Tracon Hitpointiin!",
front_page_text="<h2>Tervetuloa ostamaan pääsylippuja Tracon Hitpoint -tapahtumaan!</h2>"
"<p>Liput maksetaan suomalaisilla verkkopankkitunnuksilla heti tilauksen yhteydessä.</p>"
"<p>Lue lisää tapahtumasta <a href='http://2015.hitpoint.tracon.fi'>Tracon Hitpoint -tapahtuman kotisivuilta</a>.</p>"
"<p>Huom! Tämä verkkokauppa palvelee ainoastaan asiakkaita, joilla on osoite Suomessa. Mikäli tarvitset "
"toimituksen ulkomaille, ole hyvä ja ota sähköpostitse yhteyttä: <em>[email protected]</em>"
)
if self.test:
t = now()
defaults.update(
ticket_sales_starts=t - timedelta(days=60),
ticket_sales_ends=t + timedelta(days=60),
)
else:
# TODO
# defaults.update(
# ticket_sales_starts=datetime(2015, 3, 4, 18, 0, tzinfo=self.tz),
# ticket_sales_ends=datetime(2015, 6, 28, 18, 0, tzinfo=self.tz),
# )
pass
meta, unused = TicketsEventMeta.objects.get_or_create(event=self.event, defaults=defaults)
def limit_group(description, limit):
limit_group, unused = LimitGroup.objects.get_or_create(
event=self.event,
description=description,
defaults=dict(limit=limit),
)
return limit_group
for product_info in [
dict(
name='Tracon Hitpoint -pääsylippu',
description='Viikonloppulippu Tracon Hitpoint -tapahtumaan. Voimassa koko viikonlopun ajan la klo 12 – su klo 18. Toimitetaan sähköpostitse PDF-tiedostona, jossa olevaa viivakoodia vastaan saat rannekkeen tapahtumaan saapuessasi.',
limit_groups=[
limit_group('Pääsyliput', 400),
],
price_cents=1000,
requires_shipping=False,
electronic_ticket=True,
available=True,
ordering=self.get_ordering_number(),
),
]:
name = product_info.pop('name')
limit_groups = product_info.pop('limit_groups')
product, unused = Product.objects.get_or_create(
event=self.event,
name=name,
defaults=product_info
)
if not product.limit_groups.exists():
product.limit_groups = limit_groups
product.save()
示例3: setup_tickets
def setup_tickets(self):
from tickets.models import TicketsEventMeta, LimitGroup, Product
tickets_admin_group, = TicketsEventMeta.get_or_create_groups(self.event, ['admins'])
defaults = dict(
admin_group=tickets_admin_group,
due_days=14,
shipping_and_handling_cents=0,
reference_number_template="2019{:06d}",
contact_email='Matsucon <[email protected]>',
ticket_free_text=
"Tämä on sähköinen lippusi Matsucon 2019 -tapahtumaan. Sähköinen lippu vaihdetaan\n"
"rannekkeeseen lipunvaihtopisteessä saapuessasi tapahtumaan. Voit tulostaa tämän lipun tai\n"
"näyttää sen älypuhelimen tai tablettitietokoneen näytöltä. Mikäli kumpikaan näistä ei ole\n"
"mahdollista, ota ylös kunkin viivakoodin alla oleva neljästä tai viidestä sanasta koostuva\n"
"Kissakoodi ja ilmoita se lipunvaihtopisteessä.\n\n"
"Tervetuloa Matsuconhin!",
front_page_text="<h2>Tervetuloa ostamaan pääsylippuja Matsucon 2019 -tapahtumaan!</h2>"
"<p>Liput maksetaan suomalaisilla verkkopankkitunnuksilla heti tilauksen yhteydessä.</p>"
"<p>Lue lisää tapahtumasta <a href='http://matsucon.fi'>Matsucon 2019 -tapahtuman kotisivuilta</a>.</p>",
)
if self.test:
t = now()
defaults.update(
ticket_sales_starts=t - timedelta(days=60),
ticket_sales_ends=t + timedelta(days=60),
)
meta, unused = TicketsEventMeta.objects.get_or_create(event=self.event, defaults=defaults)
def limit_group(description, limit):
limit_group, unused = LimitGroup.objects.get_or_create(
event=self.event,
description=description,
defaults=dict(limit=limit),
)
return limit_group
def ordering():
ordering.counter += 10
return ordering.counter
ordering.counter = 0
for product_info in [
dict(
name='Viikonlopun lippu',
description='Viikonloppulippu oikeuttaa sisäänpääsyyn Matsuconin kumpanakin päivänä (3.–4.8.). Sähköinen lippu vaihdetaan ovella rannekkeeseen.',
limit_groups=[
limit_group('Viikonloppuliput', 460),
],
price_cents=1500,
requires_shipping=False,
electronic_ticket=True,
available=True,
ordering=ordering(),
),
dict(
name='Lauantain lippu',
description='Lauantailippu oikeuttaa sisäänpääsyyn Matsuconin ensimmäisenä päivänä (3.8.). Sähköinen lippu vaihdetaan ovella rannekkeeseen.',
limit_groups=[
limit_group('Lauantailiput', 125),
],
price_cents=1000,
requires_shipping=False,
electronic_ticket=True,
available=True,
ordering=ordering(),
),
dict(
name='Sunnuntain lippu',
description='Sunnuntailippu oikeuttaa sisäänpääsyyn Matsuconin toisena päivänä (4.8.). Sähköinen lippu vaihdetaan ovella rannekkeeseen.',
limit_groups=[
limit_group('Sunnuntailiput', 110),
],
price_cents=1000,
requires_shipping=False,
electronic_ticket=True,
available=True,
ordering=ordering(),
),
# dict(
# name='Lattiamajoitus',
# description='Lattiamajoitus lauantain ja sunnuntain väliselle yölle tapahtumapaikalla.',
# limit_groups=[
# limit_group('Lattiamajoituspaikat', 40),
# ],
# price_cents=700,
# requires_shipping=False,
# electronic_ticket=False,
# requires_accommodation_information=True,
# available=True,
# ordering=ordering(),
# ),
#.........這裏部分代碼省略.........
示例4: setup_tickets
def setup_tickets(self):
from tickets.models import TicketsEventMeta, LimitGroup, Product
tickets_admin_group, = TicketsEventMeta.get_or_create_groups(self.event, ['admins'])
defaults = dict(
admin_group=tickets_admin_group,
due_days=14,
shipping_and_handling_cents=0,
reference_number_template="2019{:06}",
contact_email='Nekocon (2019) <[email protected]>',
ticket_free_text="Tämä on sähköinen lippusi vuoden 2019 Nekoconiin. Sähköinen lippu vaihdetaan rannekkeeseen\n"
"lipunvaihtopisteessä saapuessasi tapahtumaan. Voit tulostaa tämän lipun tai näyttää sen\n"
"älypuhelimen tai tablettitietokoneen näytöltä. Mikäli kumpikaan näistä ei ole mahdollista, ota ylös\n"
"kunkin viivakoodin alla oleva neljästä tai viidestä sanasta koostuva Kissakoodi ja ilmoita se\n"
"lipunvaihtopisteessä.\n\n"
"Tervetuloa Nekocon (2019) -tapahtumaan!",
front_page_text="<h2>Tervetuloa ostamaan pääsylippuja Nekoconiin!</h2>"
"<p>Liput maksetaan suomalaisilla verkkopankkitunnuksilla heti tilauksen yhteydessä.</p>"
"<p>Lue lisää tapahtumasta <a href='http://nekocon.fi'>Nekoconin kotisivuilta</a>.</p>"
)
if self.test:
t = now()
defaults.update(
ticket_sales_starts=t - timedelta(days=60),
ticket_sales_ends=t + timedelta(days=60),
)
meta, unused = TicketsEventMeta.objects.get_or_create(event=self.event, defaults=defaults)
def limit_group(description, limit):
limit_group, unused = LimitGroup.objects.get_or_create(
event=self.event,
description=description,
defaults=dict(limit=limit),
)
return limit_group
for product_info in [
dict(
name='Nekocon (2019) -pääsylippu',
description='Viikonloppuranneke Kuopiossa järjestettävään vuoden 2019 Nekoconiin. Huom. myynnissä vain viikonloppurannekkeita. E-lippu vaihdetaan ovella rannekkeeseen.',
limit_groups=[
limit_group('Pääsyliput', 3000),
],
price_cents=2200,
requires_shipping=False,
electronic_ticket=True,
available=True,
ordering=self.get_ordering_number(),
),
dict(
name='Lattiamajoituspaikka (koko vkl)',
description='Lattiamajoituspaikka molemmiksi öiksi pe-la ja la-su. Majoitus aukeaa perjantaina 18:00 ja sulkeutuu sunnuntaina 12:00.',
limit_groups=[
limit_group('Lattiamajoitus pe-la', 220),
limit_group('Lattiamajoitus la-su', 220),
],
price_cents=1500,
requires_shipping=False,
electronic_ticket=False,
requires_accommodation_information=True,
available=True,
ordering=self.get_ordering_number(),
),
# dict(
# name='Lattiamajoituspaikka (pe-la)',
# description='Lattiamajoituspaikka perjantain ja lauantain väliseksi yöksi. Majoituksesta lisää tietoa sivuillamme www.nekocon.fi.',
# limit_groups=[
# limit_group('Lattiamajoitus pe-la', 445),
# ],
# price_cents=700,
# requires_shipping=False,
# electronic_ticket=False,
# available=True,
# ordering=self.get_ordering_number(),
# ),
# dict(
# name='Lattiamajoituspaikka (la-su)',
# description='Lattiamajoituspaikka lauantain ja sunnuntain väliseksi yöksi. Majoituksesta lisää tietoa sivuillamme www.nekocon.fi.',
# limit_groups=[
# limit_group('Lattiamajoitus la-su', 445),
# ],
# price_cents=700,
# requires_shipping=False,
# electronic_ticket=False,
# available=True,
# ordering=self.get_ordering_number(),
# ),
# dict(
# name='Nekocon (2019) -konserttilippu',
# description='Lippu Nekoconin konserttiin. Mikäli tarvitset pyörätuolipaikkaa, otathan ennen ostoa yhteyttä <em>[email protected]</em>, jotta voimme varmistaa paikkatilanteen.',
# limit_groups=[
# limit_group('Konserttiliput', 820),
# ],
# price_cents=500,
# requires_shipping=True,
# electronic_ticket=False,
#.........這裏部分代碼省略.........
示例5: setup_tickets
def setup_tickets(self):
from tickets.models import TicketsEventMeta, LimitGroup, Product
tickets_admin_group, = TicketsEventMeta.get_or_create_groups(self.event, ['admins'])
defaults = dict(
admin_group=tickets_admin_group,
due_days=14,
shipping_and_handling_cents=0,
reference_number_template="2015{:05d}",
contact_email='Traconin lipunmyynti <[email protected]>',
plain_contact_email='[email protected]',
ticket_free_text=u"Tämä on sähköinen lippusi Tracon X -tapahtumaan. Sähköinen lippu vaihdetaan rannekkeeseen\n"
u"lipunvaihtopisteessä saapuessasi tapahtumaan. Voit tulostaa tämän lipun tai näyttää sen\n"
u"älypuhelimen tai tablettitietokoneen näytöltä. Mikäli kumpikaan näistä ei ole mahdollista, ota ylös\n"
u"kunkin viivakoodin alla oleva neljästä tai viidestä sanasta koostuva sanakoodi ja ilmoita se\n"
u"lipunvaihtopisteessä.\n\n"
u"Tervetuloa Traconiin!",
front_page_text=u"<h2>Tervetuloa ostamaan pääsylippuja Tracon X -tapahtumaan!</h2>"
u"<p>Liput maksetaan suomalaisilla verkkopankkitunnuksilla heti tilauksen yhteydessä.</p>"
u"<p>Lue lisää tapahtumasta <a href='http://2015.tracon.fi'>Traconin kotisivuilta</a>.</p>",
)
if self.test:
t = now()
defaults.update(
ticket_sales_starts=t - timedelta(days=60),
ticket_sales_ends=t + timedelta(days=60),
)
else:
defaults.update(
ticket_sales_starts=datetime(2014, 12, 1, 0, 0, tzinfo=self.tz),
ticket_sales_ends=datetime(2015, 12, 12, 23, 59, 59, tzinfo=self.tz),
)
meta, unused = TicketsEventMeta.objects.get_or_create(event=self.event, defaults=defaults)
def limit_group(description, limit):
limit_group, unused = LimitGroup.objects.get_or_create(
event=self.event,
description=description,
defaults=dict(limit=limit),
)
return limit_group
def ordering():
ordering.counter += 10
return ordering.counter
ordering.counter = 0
for product_info in [
dict(
name=u'Joulupaketti - 2 kpl viikonloppulippu ja 1 kpl kalenteri',
description=u'Paketti sisältää kaksi viikonloppulippua ja yhden Tracon 2015 -seinäkalenterin. Tuotteet toimitetaan antamaasi osoitteeseen postitse, ja postikulut sisältyvät hintaan.',
internal_description=u'HUOM! Järjestelmä ei tue lippukiintiöiden kuluttamista kahdella per myyty paketti, joten lippukiintiöt täytyy korjata käsin kun joulupaketit on myyty.',
limit_groups=[
# limit_group('Lauantain liput', 5000, 2),
# limit_group('Sunnuntain liput', 5000, 2),
limit_group('Joulupaketti A', 80),
],
price_cents=6000,
requires_shipping=True,
electronic_ticket=False,
available=False,
ordering=ordering(),
),
dict(
name=u'Joulupaketti - 1 kpl viikonloppulippu ja 1 kpl kalenteri',
description=u'Paketti sisältää yhden viikonloppulipun ja yhden Tracon 2015 -seinäkalenterin. Tuotteet toimitetaan antamaasi osoitteeseen postitse, ja postikulut sisältyvät hintaan.',
limit_groups=[
limit_group('Lauantain liput', 3525),
limit_group('Sunnuntain liput', 3525),
limit_group('Joulupaketti B', 80),
],
price_cents=3500,
requires_shipping=True,
electronic_ticket=False,
available=False,
ordering=ordering(),
),
dict(
name=u'Viikonloppulippu',
description=u'Viikonloppulippu Tracon 2015 -tapahtumaan. Voimassa koko viikonlopun ajan la klo 10 – su klo 18. Toimitetaan sähköpostitse PDF-tiedostona, jossa olevaa viivakoodia vastaan saat rannekkeen tapahtumaan saapuessasi.',
limit_groups=[
limit_group('Lauantain liput', 3525),
limit_group('Sunnuntain liput', 3525),
],
price_cents=2500,
requires_shipping=False,
electronic_ticket=True,
available=True,
ordering=ordering(),
),
dict(
name=u'Lauantailippu',
description=u'Lauantailippu Tracon 2015 -tapahtumaan. Voimassa koko lauantaipäivän ajan la klo 10 – su klo 08. Toimitetaan sähköpostitse PDF-tiedostona, jossa olevaa viivakoodia vastaan saat rannekkeen tapahtumaan saapuessasi.',
limit_groups=[
limit_group('Lauantain liput', 3525),
],
#.........這裏部分代碼省略.........
示例6: setup_tickets
def setup_tickets(self):
from tickets.models import TicketsEventMeta, LimitGroup, Product
tickets_admin_group, = TicketsEventMeta.get_or_create_groups(self.event, ['admins'])
defaults = dict(
admin_group=tickets_admin_group,
due_days=14,
shipping_and_handling_cents=0,
reference_number_template="2015{:05d}",
contact_email='Yukicon <[email protected]>',
plain_contact_email='[email protected]',
ticket_free_text=u"Tämä on sähköinen lippusi Yukicon 2.0 -tapahtumaan. Sähköinen lippu vaihdetaan rannekkeeseen\n"
u"lipunvaihtopisteessä saapuessasi tapahtumaan. Voit tulostaa tämän lipun tai näyttää sen\n"
u"älypuhelimen tai tablettitietokoneen näytöltä. Mikäli kumpikaan näistä ei ole mahdollista, ota ylös\n"
u"kunkin viivakoodin alla oleva neljästä tai viidestä sanasta koostuva sanakoodi ja ilmoita se\n"
u"lipunvaihtopisteessä.\n\n"
u"Tervetuloa Yukiconiin!",
front_page_text=u"<h2>Tervetuloa ostamaan pääsylippuja Yukicon 2.0 -tapahtumaan!</h2>"
u"<p>Liput maksetaan suomalaisilla verkkopankkitunnuksilla heti tilauksen yhteydessä.</p>"
u"<p>Lue lisää tapahtumasta <a href='http://www.yukicon.fi'>Yukiconin kotisivuilta</a>.</p>",
)
if self.test:
t = now()
defaults.update(
ticket_sales_starts=t - timedelta(days=60),
ticket_sales_ends=t + timedelta(days=60),
)
else:
defaults.update(
ticket_sales_starts=datetime(2014, 11, 20, 18, 0, tzinfo=self.tz),
ticket_sales_ends=datetime(2015, 1, 11, 18, 0, tzinfo=self.tz),
)
meta, unused = TicketsEventMeta.objects.get_or_create(event=self.event, defaults=defaults)
def limit_group(description, limit):
limit_group, unused = LimitGroup.objects.get_or_create(
event=self.event,
description=description,
defaults=dict(limit=limit),
)
return limit_group
def ordering():
ordering.counter += 10
return ordering.counter
ordering.counter = 0
for product_info in [
dict(
name=u'Yukicon 2015 -pääsylippu',
description=u'Lippu kattaa koko viikonlopun. Maksettuasi sinulle lähetetään PDF-lippu antamaasi sähköpostiin, jota vastaan saat rannekkeen tapahtuman ovelta.',
limit_groups=[
limit_group('Pääsyliput', 1450),
],
price_cents=1700,
requires_shipping=False,
electronic_ticket=True,
available=True,
ordering=ordering(),
),
]:
name = product_info.pop('name')
limit_groups = product_info.pop('limit_groups')
product, unused = Product.objects.get_or_create(
event=self.event,
name=name,
defaults=product_info
)
if not product.limit_groups.exists():
product.limit_groups = limit_groups
product.save()
示例7: setup_tickets
def setup_tickets(self):
from tickets.models import TicketsEventMeta, LimitGroup, Product
tickets_admin_group, = TicketsEventMeta.get_or_create_groups(self.event, ['admins'])
defaults = dict(
admin_group=tickets_admin_group,
due_days=14,
shipping_and_handling_cents=0,
reference_number_template="2017{:05d}",
contact_email='Looking for Alice <[email protected]>',
ticket_free_text=(
"Tämä on sähköinen lippusi Looking for Alice -tapahtumaan. Voit tulostaa tämän lipun tai\n"
"näyttää sen älypuhelimen tai tablettitietokoneen näytöltä. Mikäli kumpikaan näistä ei ole\n"
"mahdollista, ota ylös kunkin viivakoodin alla oleva neljästä tai viidestä sanasta koostuva\n"
"Kissakoodi ja ilmoita se lipunvaihtopisteessä.\n\n"
"This is your electronic ticket to Looking for Alice. You can print it or show it from your\n"
"smartphone or tablet. If neither of these are suitable for you, please write down the four\n"
"to six Finnish words under the barcode – they will function as your ticket code at the\n"
"ticket exchange point.\n\n"
"Tervetuloa Looking for Alice -tapahtumaan! Welcome to Looking for Alice!"
),
front_page_text=(
"<h2>Tervetuloa ostamaan pääsylippuja Looking for Alice -tapahtumaan!</h2>"
"<p>Liput maksetaan suomalaisilla verkkopankkitunnuksilla tai luottokortilla heti tilauksen yhteydessä.</p>"
"<h2>Welcome to the Looking for Alice ticket shop!</h2>"
"<p>We accept Finnish Internet bank payments and international credit cards.</p>"
),
)
if self.test:
t = now()
defaults.update(
ticket_sales_starts=t - timedelta(days=60),
ticket_sales_ends=t + timedelta(days=60),
)
else:
defaults.update(
ticket_sales_starts=datetime(2016, 12, 11, 18, 0, tzinfo=self.tz),
# ticket_sales_ends=datetime(2015, 1, 11, 18, 0, tzinfo=self.tz),
)
meta, unused = TicketsEventMeta.objects.get_or_create(event=self.event, defaults=defaults)
def limit_group(description, limit):
limit_group, unused = LimitGroup.objects.get_or_create(
event=self.event,
description=description,
defaults=dict(limit=limit),
)
return limit_group
def ordering():
ordering.counter += 10
return ordering.counter
ordering.counter = 0
for product_info in [
dict(
name='The White Rabbit',
description=(
'The White Rabbit -lippu johdattaa sinut seikkailuun sekä In The Wonderland -päiväosioon että Through the Looking Glass -iltaosioon.\n\n'
'The White Rabbit – a regular full day ticket, includes entrance to the In the Wonderland day section and Through the Looking Glass evening section.'
),
limit_groups=[
limit_group('The White Rabbit', 130),
],
price_cents=5500,
requires_shipping=False,
electronic_ticket=True,
available=True,
ordering=ordering(),
),
dict(
name='The Queen of Hearts',
description=(
'Kuninkaallisen menon takaa The Queen of Hearts-lippu, jolla pääset päiväosioon aikaisemmin sisälle ja saat sisäänpääsyn Through the Looking Glass -iltaosioon. Lisäksi lippu sisältää kuva-session upeiden kunniavieraidemme kanssa ihanan Sanni Siiran kuvaamana sekä pienen lahjakassin!\n\n'
'The Queen of Hearts – Vip full day ticket, includes early entrance to the In the Wonderland day section and entrance to the Through the looking Glass evening section. The ticket also includes a small goodie bag and a photosession with the guests of honors by Sanni Siira!'
),
limit_groups=[
limit_group('The Queen of Hearts', 30),
],
price_cents=7000,
requires_shipping=False,
electronic_ticket=True,
available=True,
ordering=15,
),
dict(
name='Through the Looking Glass',
description=(
'Through the Looking Glass -lipulla pääset osallistumaan Through the Looking Glass -iltaosioon.\n\n'
'Through the Looking Glass – evening section ticket. This ticket allows an entrance to the Through the Looking Glass evening section of the event.'
),
limit_groups=[
limit_group('Through the Looking Glass', 100),
#.........這裏部分代碼省略.........
示例8: setup_tickets
def setup_tickets(self):
from tickets.models import TicketsEventMeta, LimitGroup, Product
tickets_admin_group, pos_access_group = TicketsEventMeta.get_or_create_groups(self.event, ['admins', 'pos'])
defaults = dict(
admin_group=tickets_admin_group,
pos_access_group=pos_access_group,
due_days=14,
shipping_and_handling_cents=0,
reference_number_template="2019{:05d}",
contact_email='Ropecon 2019 -lipunmyynti <[email protected]>',
ticket_free_text="Tämä on sähköinen lippusi Ropecon 2019 -tapahtumaan. Sähköinen lippu vaihdetaan rannekkeeseen\n"
"lipunvaihtopisteessä saapuessasi tapahtumaan. Voit tulostaa tämän lipun tai näyttää sen\n"
"älypuhelimen tai tablettitietokoneen näytöltä. Mikäli kumpikaan näistä ei ole mahdollista, ota ylös\n"
"kunkin viivakoodin alla oleva neljästä tai viidestä sanasta koostuva Kissakoodi ja ilmoita se\n"
"lipunvaihtopisteessä.\n\n"
"Tervetuloa Ropeconiin!",
front_page_text="<h2>Tervetuloa Ropeconin lippukauppaan!</h2>"
"<p>Liput maksetaan tilauksen yhteydessä käyttämällä suomalaia verkkopankkipalveluja.</p>"
"<p>Maksetut liput toimitetaan e-lippuina sähköpostitse asiakkaan antamaan osoitteeseen. E-liput vaihdetaan rannekkeiksi tapahtuman lipunmyyntipisteillä 27.–29.7.2019.</p>"
"<p>Lisätietoja lipuista saat tapahtuman verkkosivuilta. <a href='https://2019.ropecon.fi/liput/'>Siirry takaisin tapahtuman verkkosivuille</a>.</p>"
"<p>Huom! Tämä verkkokauppa palvelee ainoastaan asiakkaita, joilla on osoite Suomessa. Mikäli tarvitset "
"toimituksen ulkomaille, ole hyvä ja ota sähköpostitse yhteyttä: <em>[email protected]</em>"
)
if self.test:
t = now()
defaults.update(
ticket_sales_starts=t - timedelta(days=60),
ticket_sales_ends=t + timedelta(days=60),
)
else:
defaults.update(
ticket_sales_starts=datetime(2019, 2, 28, 10, 0, tzinfo=self.tz),
ticket_sales_ends=datetime(2019, 7, 26, 0, 0, tzinfo=self.tz),
)
meta, unused = TicketsEventMeta.objects.get_or_create(event=self.event, defaults=defaults)
def limit_group(description, limit):
limit_group, unused = LimitGroup.objects.get_or_create(
event=self.event,
description=description,
defaults=dict(limit=limit),
)
return limit_group
for product_info in [
dict(
name='Ropecon 2019 Early Dragon -viikonloppulippu',
description='Sisältää pääsyn Ropecon 2019 -tapahtumaan koko viikonlopun ajan.',
limit_groups=[
limit_group('Pääsyliput', 9999),
],
price_cents=4000,
requires_shipping=False,
electronic_ticket=True,
available=True,
ordering=self.get_ordering_number(),
),
dict(
name='Ropecon 2019 Lasten Early Dragon -viikonloppulippu',
description='Sisältää pääsyn lapselle (7-12 v) Ropecon 2019 -tapahtumaan koko viikonlopun ajan.',
limit_groups=[
limit_group('Pääsyliput', 9999),
],
price_cents=2000,
requires_shipping=False,
electronic_ticket=True,
available=True,
ordering=self.get_ordering_number(),
),
dict(
name='Ropecon 2019 Ennakkoviikonloppulippu',
description='Sisältää pääsyn Ropecon 2019 -tapahtumaan koko viikonlopun ajan.',
limit_groups=[
limit_group('Pääsyliput', 9999),
],
price_cents=4500,
requires_shipping=False,
electronic_ticket=True,
available=False,
ordering=self.get_ordering_number(),
),
dict(
name='Ropecon 2019 Lasten ennakkoviikonloppulippu',
description='Sisältää pääsyn lapselle (7-12 v) Ropecon 2019 -tapahtumaan koko viikonlopun ajan.',
limit_groups=[
limit_group('Pääsyliput', 9999),
],
price_cents=2500,
requires_shipping=False,
electronic_ticket=True,
available=False,
ordering=self.get_ordering_number(),
),
dict(
name='Ropecon 2019 Perheviikonloppulippupaketti',
#.........這裏部分代碼省略.........
示例9: handle
#.........這裏部分代碼省略.........
start_time=datetime(2014, 9, 13, 10, 30, 0, tzinfo=tz),
)
for view_name, room_names in [
(u'Pääohjelmatilat', [
u'Iso sali',
u'Pieni sali',
u'Studio',
u'Sonaatti 1',
u'Sonaatti 2',
u'Sopraano',
]),
(u'Toissijaiset ohjelmatilat', [
u'Opus 1',
u'Puistolava',
u'Puisto - Iso miittiteltta',
u'Puisto - Pieni miittiteltta',
]),
]:
rooms = [Room.objects.get(name__iexact=room_name, venue=venue)
for room_name in room_names]
view, created = View.objects.get_or_create(event=event, name=view_name)
if created:
view.rooms = rooms
view.save()
#
# Tickets
#
tickets_admin_group, = TicketsEventMeta.get_or_create_groups(event, ['admins'])
give_all_app_perms_to_group('tickets', tickets_admin_group)
tickets_event_meta_defaults = dict(
admin_group=tickets_admin_group,
due_days=14,
shipping_and_handling_cents=100,
reference_number_template='9{:05d}',
contact_email='Tracon 9 -lipunmyynti <[email protected]>',
plain_contact_email='[email protected]',
ticket_spam_email='[email protected]',
ticket_free_text=u"Tämä on sähköinen lippusi Tracon 9 -tapahtumaan. Sähköinen lippu vaihdetaan rannekkeeseen\n"
u"lipunvaihtopisteessä saapuessasi tapahtumaan. Voit tulostaa tämän lipun tai näyttää sen\n"
u"älypuhelimen tai tablettitietokoneen näytöltä. Mikäli kumpikaan näistä ei ole mahdollista, ota ylös\n"
u"kunkin viivakoodin alla oleva neljästä tai viidestä sanasta koostuva sanakoodi ja ilmoita se\n"
u"lipunvaihtopisteessä.\n\n"
u"Tervetuloa Traconiin!"
)
if settings.DEBUG:
t = now()
tickets_event_meta_defaults.update(
ticket_sales_starts=t - timedelta(days=60),
ticket_sales_ends=t + timedelta(days=60),
)
else:
tickets_event_meta_defaults.update(
ticket_sales_starts=datetime(2014, 3, 1, 0, 0, tzinfo=tz),
ticket_sales_ends=datetime(2014, 8, 31, 0, 0, tzinfo=tz),
)
tickets_meta, unused = TicketsEventMeta.objects.get_or_create(
event=event,
示例10: setup_tickets
def setup_tickets(self):
from tickets.models import TicketsEventMeta, LimitGroup, Product
tickets_admin_group, = TicketsEventMeta.get_or_create_groups(self.event, ['admins'])
defaults = dict(
admin_group=tickets_admin_group,
due_days=14,
shipping_and_handling_cents=0,
reference_number_template="2017{:05d}",
contact_email='Yukicon <[email protected]>',
ticket_free_text="Tämä on sähköinen lippusi. Sähköinen lippu vaihdetaan rannekkeeseen\n"
"lipunvaihtopisteessä saapuessasi tapahtumaan. Voit tulostaa tämän lipun tai näyttää sen\n"
"älypuhelimen tai tablettitietokoneen näytöltä. Mikäli kumpikaan näistä ei ole mahdollista, ota ylös\n"
"kunkin viivakoodin alla oleva neljästä tai viidestä sanasta koostuva sanakoodi ja ilmoita se\n"
"lipunvaihtopisteessä.\n\n"
"Tervetuloa tapahtumaan!",
front_page_text="<h2>Tervetuloa ostamaan pääsylippuja Yukicon 4.0- ja Pyrycon-tapahtumiin!</h2>"
"<p>Liput maksetaan suomalaisilla verkkopankkitunnuksilla heti tilauksen yhteydessä.</p>"
"<p>Lue lisää tapahtumasta <a href='http://www.yukicon.fi' target='_blank'>Yukiconin kotisivuilta</a>.</p>",
print_logo_path=mkpath('static', 'images', 'yukicon2017_logo.jpg'),
print_logo_width_mm=50,
print_logo_height_mm=16
)
if self.test:
t = now()
defaults.update(
ticket_sales_starts=t - timedelta(days=60),
ticket_sales_ends=t + timedelta(days=60),
)
meta, unused = TicketsEventMeta.objects.get_or_create(event=self.event, defaults=defaults)
if 'yukicon_436_test' in meta.print_logo_path or 'png' in meta.print_logo_path:
meta.print_logo_path = mkpath('static', 'images', 'yukicon2017_logo.jpg')
meta.print_logo_height_mm = 16
meta.save()
def limit_group(description, limit):
limit_group, unused = LimitGroup.objects.get_or_create(
event=self.event,
description=description,
defaults=dict(limit=limit),
)
return limit_group
for product_info in [
dict(
name='Yukicon 4.0 – Early Access',
description='Early Access -lipulla pääset Yukiconiin 18.–19.2.2017. Lippu oikeuttaa Early Access -etuuksien lunastuksen. Lippu ei oikeuta pääsyä Pyryconiin. Maksettuasi sinulle lähetetään PDF-lippu antamaasi sähköpostiin, jota vastaan saat rannekkeen tapahtuman ovelta.',
limit_groups=[
limit_group('Early Access', 200),
],
price_cents=2900,
requires_shipping=False,
electronic_ticket=True,
available=True,
ordering=self.get_ordering_number(),
),
dict(
name='Pyryconin pääsylippu',
description='Lipulla pääset Pyryconiin perjantaina 17. helmikuuta 2017. Lippu ei oikeuta pääsyä Yukiconiin. Maksettuasi sinulle lähetetään PDF-lippu antamaasi sähköpostiin, jota vastaan saat rannekkeen tapahtuman ovelta. Ei palautus- tai vaihto-oikeutta.',
limit_groups=[
limit_group('Pyrycon', 1200),
],
price_cents=600,
requires_shipping=False,
electronic_ticket=True,
available=True,
ordering=self.get_ordering_number(),
),
]:
name = product_info.pop('name')
limit_groups = product_info.pop('limit_groups')
product, unused = Product.objects.get_or_create(
event=self.event,
name=name,
defaults=product_info
)
if not product.limit_groups.exists():
product.limit_groups = limit_groups
product.save()
示例11: setup_tickets
def setup_tickets(self):
from tickets.models import TicketsEventMeta, LimitGroup, Product, ShirtType, ShirtSize
tickets_admin_group, = TicketsEventMeta.get_or_create_groups(self.event, ['admins'])
defaults = dict(
admin_group=tickets_admin_group,
due_days=14,
shipping_and_handling_cents=0,
reference_number_template="2017{:05d}",
contact_email='Ropeconin lipunmyynti <[email protected]>',
front_page_text=(
"<h2>Tervetuloa ostamaan pääsylippuja Ropeconiin!</h2>"
"<p>Liput maksetaan suomalaisilla verkkopankkitunnuksilla heti tilauksen yhteydessä. Liput lähetetään "
"sähköpostitse e-lippuina, jotka vaihdetaan rannekkeiksi saapuessasi tapahtumaan.</p>"
"<p>Lue lisää tapahtumasta <a href='http://ropecon.fi'>Ropeconin kotisivuilta</a>.</p>"
),
)
if self.test:
t = now()
defaults.update(
ticket_sales_starts=t - timedelta(days=60),
ticket_sales_ends=t + timedelta(days=60),
)
else:
# defaults.update(
# ticket_sales_starts=datetime(2015, 1, 25, 18, 0, tzinfo=self.tz),
# # ticket_sales_ends=datetime(2015, 1, 11, 18, 0, tzinfo=self.tz),
# )
pass
meta, unused = TicketsEventMeta.objects.get_or_create(event=self.event, defaults=defaults)
def limit_group(description, limit):
limit_group, unused = LimitGroup.objects.get_or_create(
event=self.event,
description=description,
defaults=dict(limit=limit),
)
return limit_group
def ordering():
ordering.counter += 10
return ordering.counter
ordering.counter = 0
for product_info in [
dict(
name='Ropecon 2017 viikonloppulippu pe–su (Norppa & Kultisti -kampanja)',
description=(
'Ropecon 2017 -tapahtuman pääsylippu, joka oikeuttaa kolmen päivän '
'sisäänpääsyrannekkeeseen. Kun tilaat lippusi 28.2. mennessä, saat myös Norppa & Kultisti '
'-kangasmerkin!'
),
limit_groups=[
limit_group('Pääsyliput perjantai', 10000),
limit_group('Pääsyliput lauantai', 10000),
limit_group('Pääsyliput sunnuntai', 10000),
],
price_cents=3500,
requires_shipping=False,
electronic_ticket=True,
available=True,
ordering=ordering(),
),
dict(
name='Ropecon 2017 viikonloppulippu pe–su',
description=(
'Ropecon 2017 -tapahtuman pääsylippu, joka oikeuttaa kolmen päivän '
'sisäänpääsyrannekkeeseen.'
),
limit_groups=[
limit_group('Pääsyliput perjantai', 10000),
limit_group('Pääsyliput lauantai', 10000),
limit_group('Pääsyliput sunnuntai', 10000),
],
price_cents=3500,
requires_shipping=False,
electronic_ticket=True,
available=False,
ordering=ordering(),
),
dict(
name='Ropecon 2017 Conformers -paita',
description=(
'T-paidat maksetaan ennakkoon ja noudetaan tapahtumasta. Paitakoot valitaan seuraavassa '
'vaiheessa. <a href="https://2017.ropecon.fi/spessupaita-2017/" target="_blank">Lue lisää '
'paitamalleista ja katso kokotaulukot</a>'
),
limit_groups=[
limit_group('T-paidat', 10000),
],
price_cents=3000,
requires_shipping=False,
electronic_ticket=True,
requires_shirt_size=True,
available=True,
ordering=ordering(),
#.........這裏部分代碼省略.........
示例12: setup_tickets
def setup_tickets(self):
from tickets.models import TicketsEventMeta, LimitGroup, Product
tickets_admin_group, pos_access_group = TicketsEventMeta.get_or_create_groups(self.event, ['admins', 'pos'])
defaults = dict(
admin_group=tickets_admin_group,
due_days=14,
shipping_and_handling_cents=0,
reference_number_template="2018{:05d}",
contact_email='Ropecon 2018 -lipunmyynti <[email protected]>',
ticket_free_text="Tämä on sähköinen lippusi Ropecon 2018 -tapahtumaan. Sähköinen lippu vaihdetaan rannekkeeseen\n"
"lipunvaihtopisteessä saapuessasi tapahtumaan. Voit tulostaa tämän lipun tai näyttää sen\n"
"älypuhelimen tai tablettitietokoneen näytöltä. Mikäli kumpikaan näistä ei ole mahdollista, ota ylös\n"
"kunkin viivakoodin alla oleva neljästä tai viidestä sanasta koostuva Kissakoodi ja ilmoita se\n"
"lipunvaihtopisteessä.\n\n"
"Tervetuloa Ropeconiin!",
front_page_text="<h2>Tervetuloa Ropeconin lippukauppaan!</h2>"
"<p>Liput maksetaan tilauksen yhteydessä käyttämällä suomalaia verkkopankkipalveluja.</p>"
"<p>Maksetut liput toimitetaan e-lippuina sähköpostitse asiakkaan antamaan osoitteeseen. E-liput vaihdetaan rannekkeiksi tapahtuman lipunmyyntipisteillä 27.–29.7.2018.</p>"
"<p>Lisätietoja lipuista saat tapahtuman verkkosivuilta. <a href='https://2018.ropecon.fi/liput/'>Siirry takaisin tapahtuman verkkosivuille</a>.</p>"
"<p>Huom! Tämä verkkokauppa palvelee ainoastaan asiakkaita, joilla on osoite Suomessa. Mikäli tarvitset "
"toimituksen ulkomaille, ole hyvä ja ota sähköpostitse yhteyttä: <em>[email protected]</em>"
)
if self.test:
t = now()
defaults.update(
ticket_sales_starts=t - timedelta(days=60),
ticket_sales_ends=t + timedelta(days=60),
)
else:
defaults.update(
ticket_sales_starts=datetime(2018, 2, 14, 10, 0, tzinfo=self.tz),
ticket_sales_ends=datetime(2018, 7, 2, 0, 0, tzinfo=self.tz),
)
meta, unused = TicketsEventMeta.objects.get_or_create(event=self.event, defaults=defaults)
# migration 0024_ticketseventmeta_pos_access_group
if meta.pos_access_group is None:
meta.pos_access_group = pos_access_group
meta.save()
def limit_group(description, limit):
limit_group, unused = LimitGroup.objects.get_or_create(
event=self.event,
description=description,
defaults=dict(limit=limit),
)
return limit_group
for product_info in [
dict(
name='Ropecon 2018 viikonloppulippu pe-su, aikuiset',
description='Ropecon 2018-tapahtuman pääsylippu 27.-29.7.2018.',
limit_groups=[
limit_group('Pääsyliput', 9999),
],
price_cents=3800,
requires_shipping=False,
electronic_ticket=True,
available=True,
ordering=self.get_ordering_number(),
),
dict(
name='Ropecon 2018 viikonloppulippu pe-su, lapset',
description='7-12-vuotiaat lapset aikuisen seurassa.',
limit_groups=[
limit_group('Pääsyliput', 9999),
],
price_cents=2000,
requires_shipping=False,
electronic_ticket=True,
available=True,
ordering=self.get_ordering_number(),
),
dict(
name='Ropecon 2018 -tapahtuman kannatusranneke',
description='Sisältää pääsylipun Ropecon 2018 -tapahtumaan 27.–29.7.2018 sekä Ropecon ry:n jäsenyyden vuodelle 2018.',
limit_groups=[
limit_group('Pääsyliput', 9999),
],
price_cents=7000,
requires_shipping=False,
electronic_ticket=True,
available=True,
ordering=self.get_ordering_number(),
),
]:
name = product_info.pop('name')
limit_groups = product_info.pop('limit_groups')
product, unused = Product.objects.get_or_create(
event=self.event,
name=name,
defaults=product_info
)
#.........這裏部分代碼省略.........
示例13: setup_tickets
def setup_tickets(self):
from tickets.models import TicketsEventMeta, LimitGroup, Product
tickets_admin_group, = TicketsEventMeta.get_or_create_groups(self.event, ['admins'])
defaults = dict(
admin_group=tickets_admin_group,
due_days=14,
shipping_and_handling_cents=0,
reference_number_template="2016{:05d}",
contact_email='Ropeconin lipunmyynti <[email protected]>',
plain_contact_email='[email protected]',
front_page_text=u"<h2>Tervetuloa ostamaan pääsylippuja Ropeconiin!</h2>"
u"<p>Liput maksetaan suomalaisilla verkkopankkitunnuksilla heti tilauksen yhteydessä. Liput lähetetään sähköpostitse e-lippuina, jotka vaihdetaan rannekkeiksi saapuessasi tapahtumaan.</p>"
u"<p>Lue lisää tapahtumasta <a href='http://ropecon.fi'>Ropeconin kotisivuilta</a>.</p>",
)
if self.test:
t = now()
defaults.update(
ticket_sales_starts=t - timedelta(days=60),
ticket_sales_ends=t + timedelta(days=60),
)
else:
# defaults.update(
# ticket_sales_starts=datetime(2015, 1, 25, 18, 0, tzinfo=self.tz),
# # ticket_sales_ends=datetime(2015, 1, 11, 18, 0, tzinfo=self.tz),
# )
pass
meta, unused = TicketsEventMeta.objects.get_or_create(event=self.event, defaults=defaults)
def limit_group(description, limit):
limit_group, unused = LimitGroup.objects.get_or_create(
event=self.event,
description=description,
defaults=dict(limit=limit),
)
return limit_group
def ordering():
ordering.counter += 10
return ordering.counter
ordering.counter = 0
for product_info in [
dict(
name=u'Ropecon 2016 viikonloppulippu pe-su',
description=u'Ropecon 2016 tapahtuman pääsylippu oikeuttaen kolmen päivän sisäänpääsyrannekkeeseen.',
limit_groups=[
limit_group('Pääsyliput perjantai', 10000),
limit_group('Pääsyliput lauantai', 10000),
limit_group('Pääsyliput sunnuntai', 10000),
],
price_cents=3200,
requires_shipping=False,
electronic_ticket=True,
available=True,
ordering=ordering(),
),
dict(
name=u'Ropecon 2016 päivälippu perjantai',
description=u'Ropecon 2016 tapahtuman pääsylippu oikeuttaen yhden päivän sisäänpääsyrannekkeeseen.',
limit_groups=[
limit_group('Pääsyliput perjantai', 10000),
],
price_cents=2200,
requires_shipping=False,
electronic_ticket=True,
available=True,
ordering=ordering(),
),
dict(
name=u'Ropecon 2016 päivälippu lauantai',
description=u'Ropecon 2016 tapahtuman pääsylippu oikeuttaen yhden päivän sisäänpääsyrannekkeeseen.',
limit_groups=[
limit_group('Pääsyliput lauantai', 10000),
],
price_cents=2200,
requires_shipping=False,
electronic_ticket=True,
available=True,
ordering=ordering(),
),
dict(
name=u'Ropecon 2016 päivälippu sunnuntai',
description=u'Ropecon 2016 tapahtuman pääsylippu oikeuttaen yhden päivän sisäänpääsyrannekkeeseen.',
limit_groups=[
limit_group('Pääsyliput sunnuntai', 10000),
],
price_cents=1500,
requires_shipping=False,
electronic_ticket=True,
available=True,
ordering=ordering(),
),
]:
name = product_info.pop('name')
limit_groups = product_info.pop('limit_groups')
#.........這裏部分代碼省略.........
示例14: setup_tickets
def setup_tickets(self):
from tickets.models import TicketsEventMeta, LimitGroup, Product
tickets_admin_group, = TicketsEventMeta.get_or_create_groups(self.event, ['admins'])
defaults = dict(
admin_group=tickets_admin_group,
due_days=14,
shipping_and_handling_cents=120,
reference_number_template="2016{:05d}",
contact_email='Animecon 2016 <[email protected]>',
ticket_free_text="Tämä on sähköinen lippusi Animecon 2016 -tapahtumaan. Sähköinen lippu vaihdetaan rannekkeeseen\n"
"lipunvaihtopisteessä saapuessasi tapahtumaan. Voit tulostaa tämän lipun tai näyttää sen\n"
"älypuhelimen tai tablettitietokoneen näytöltä. Mikäli kumpikaan näistä ei ole mahdollista, ota ylös\n"
"kunkin viivakoodin alla oleva neljästä tai viidestä sanasta koostuva Kissakoodi ja ilmoita se\n"
"lipunvaihtopisteessä.\n\n"
"Tervetuloa Animecon 2016 -tapahtumaan!",
front_page_text="<h2>Tervetuloa ostamaan pääsylippuja Animecon 2016 -tapahtumaan!</h2>"
"<p>Liput maksetaan suomalaisilla verkkopankkitunnuksilla heti tilauksen yhteydessä.</p>"
"<p>Lue lisää tapahtumasta <a href='http://2016.animecon.fi'>Animecon 2016 -tapahtuman kotisivuilta</a>.</p>"
"<p>Huom! Tämä verkkokauppa palvelee ainoastaan asiakkaita, joilla on osoite Suomessa. Mikäli tarvitset "
"toimituksen ulkomaille, ole hyvä ja ota sähköpostitse yhteyttä: <em>[email protected]</em>"
)
if self.test:
t = now()
defaults.update(
ticket_sales_starts=t - timedelta(days=60),
ticket_sales_ends=t + timedelta(days=60),
)
meta, unused = TicketsEventMeta.objects.get_or_create(event=self.event, defaults=defaults)
def limit_group(description, limit):
limit_group, unused = LimitGroup.objects.get_or_create(
event=self.event,
description=description,
defaults=dict(limit=limit),
)
return limit_group
for product_info in [
dict(
name='Animecon 2016 -pääsylippu',
description='Viikonloppuranneke Kuopiossa järjestettävään Animecon-tapahtumaan. Huom. myynnissä vain viikonloppurannekkeita. Lippu on PDF-muotoinen e-lippu, joka vaihdetaan rannekkeeseen tapahtumaan saavuttaessa.',
limit_groups=[
limit_group('Pääsyliput', 3300),
],
price_cents=2000,
requires_shipping=False,
electronic_ticket=True,
available=True,
ordering=self.get_ordering_number(),
),
dict(
name='Lattiamajoitus Viitaniemen koululla pe-la-yöksi',
description='Lattiamajoituspaikka 8.-9.7.2016 välisenä yönä Viitaniemen koululla. Luethan ohjeet majoittumiseen Animeconin nettisivuilta. Jos maksat muitakin henkilöitä kuin itsesi, niin ilmoitathan kaikkien majoittujien yhteystiedot (nimi, puhelinnumero, sähköposti) lisätiedoissa. Emme lähetä lattiamajoituksesta erillistä lippua.',
limit_groups=[
limit_group('Majoitus Viitaniemi pe-la', 200),
],
price_cents=1000,
requires_shipping=False,
electronic_ticket=False,
requires_accommodation_information=True,
available=True,
ordering=self.get_ordering_number(),
),
dict(
name='Lattiamajoitus Viitaniemen koululla la-su-yöksi',
description='Lattiamajoituspaikka 9.-10.7.2016 välisenä yönä Viitaniemen koululla. Luethan ohjeet majoittumiseen Animeconin nettisivuilta. Jos maksat muitakin majoittujia kuin itsesi, niin ilmoitathan kaikkien majoittujien yhteystiedot (nimi, puhelinnumero, sähköposti) lisätiedoissa. Emme lähetä lattiamajoituksesta erillistä lippua.',
limit_groups=[
limit_group('Majoitus Viitaniemi la-su', 200),
],
price_cents=1000,
requires_shipping=False,
electronic_ticket=False,
requires_accommodation_information=True,
available=True,
ordering=self.get_ordering_number(),
),
dict(
name='Aamupala Viitaniemen koululla lauantaiaamuna',
description='Aamupala Viitaniemen koululla lauantaiaamuna 9.7.2016. Ilmoitathan erityisruokavalioista ja allergioista etukäteen. Jos olet varannut aamiaisen myös muille kuin itsellesi, niin ilmoitathan henkilöiden nimet lisätiedoissa.',
limit_groups=[
limit_group('Aamupala Viitaniemi la', 200),
],
price_cents=350,
requires_shipping=False,
electronic_ticket=False,
requires_accommodation_information=True,
available=True,
ordering=self.get_ordering_number(),
),
dict(
name='Aamupala Viitaniemen koululla sunnuntaiaamuna',
description='Aamupala Viitaniemen koululla sunnuntai-aamuna 10.7.2016. Ilmoitathan erityisruokavalioista ja allergioista etukäteen. Jos olet varannut aamiaisen myös muille kuin itsellesi, niin ilmoitathan henkilöiden nimet lisätiedoissa.',
limit_groups=[
limit_group('Aamupala Viitaniemi su', 200),
],
#.........這裏部分代碼省略.........
示例15: setup_tickets
def setup_tickets(self):
from tickets.models import TicketsEventMeta, LimitGroup, Product
tickets_admin_group, unused = TicketsEventMeta.get_or_create_group(self.event, 'admins')
defaults = dict(
admin_group=tickets_admin_group,
due_days=14,
shipping_and_handling_cents=0,
reference_number_template="2015{:05d}",
contact_email='Traconin lipunmyynti <[email protected]>',
plain_contact_email='[email protected]',
ticket_free_text=u"Tämä on sähköinen lippusi Tracon X -tapahtumaan. Sähköinen lippu vaihdetaan rannekkeeseen\n"
u"lipunvaihtopisteessä saapuessasi tapahtumaan. Voit tulostaa tämän lipun tai näyttää sen\n"
u"älypuhelimen tai tablettitietokoneen näytöltä. Mikäli kumpikaan näistä ei ole mahdollista, ota ylös\n"
u"kunkin viivakoodin alla oleva neljästä tai viidestä sanasta koostuva sanakoodi ja ilmoita se\n"
u"lipunvaihtopisteessä.\n\n"
u"Tervetuloa Traconiin!",
front_page_text=u"<h2>Tervetuloa ostamaan pääsylippuja Tracon X -tapahtumaan!</h2>"
u"<p>Liput maksetaan suomalaisilla verkkopankkitunnuksilla heti tilauksen yhteydessä.</p>"
u"<p>Lue lisää tapahtumasta <a href='http://2015.tracon.fi'>Traconin kotisivuilta</a>.</p>",
)
if self.test:
t = now()
defaults.update(
ticket_sales_starts=t - timedelta(days=60),
ticket_sales_ends=t + timedelta(days=60),
)
else:
defaults.update(
ticket_sales_starts=datetime(2014, 12, 1, 0, 0, tzinfo=self.tz),
ticket_sales_ends=datetime(2015, 12, 12, 23, 59, 59, tzinfo=self.tz),
)
meta, unused = TicketsEventMeta.objects.get_or_create(event=self.event, defaults=defaults)
def limit_group(description, limit):
limit_group, unused = LimitGroup.objects.get_or_create(
event=self.event,
description=description,
defaults=dict(limit=limit),
)
return limit_group
def ordering():
ordering.counter += 10
return ordering.counter
ordering.counter = 0
for product_info in [
dict(
name=u'Joulupaketti - 2 kpl viikonloppulippu ja 1 kpl kalenteri',
description=u'Paketti sisältää kaksi viikonloppulippua ja yhden Tracon 2015 -seinäkalenterin. Tuotteet toimitetaan antamaasi osoitteeseen postitse, ja postikulut sisältyvät hintaan.',
internal_description=u'HUOM! Järjestelmä ei tue lippukiintiöiden kuluttamista kahdella per myyty paketti, joten lippukiintiöt täytyy korjata käsin kun joulupaketit on myyty.',
limit_groups=[
# limit_group('Lauantain liput', 5000, 2),
# limit_group('Sunnuntain liput', 5000, 2),
limit_group('Joulupaketti A', 80),
],
price_cents=6000,
requires_shipping=True,
electronic_ticket=False,
available=True,
ordering=ordering(),
),
dict(
name=u'Joulupaketti - 1 kpl viikonloppulippu ja 1 kpl kalenteri',
description=u'Paketti sisältää yhden viikonloppulipun ja yhden Tracon 2015 -seinäkalenterin. Tuotteet toimitetaan antamaasi osoitteeseen postitse, ja postikulut sisältyvät hintaan.',
limit_groups=[
limit_group('Lauantain liput', 5000),
limit_group('Sunnuntain liput', 5000),
limit_group('Joulupaketti B', 80),
],
price_cents=3500,
requires_shipping=True,
electronic_ticket=False,
available=True,
ordering=ordering(),
),
]:
name = product_info.pop('name')
limit_groups = product_info.pop('limit_groups')
product, unused = Product.objects.get_or_create(
event=self.event,
name=name,
defaults=product_info
)
if not product.limit_groups.exists():
product.limit_groups = limit_groups
product.save()