This repository has been archived on 2024-07-22. You can view files and clone it, but cannot push or open issues or pull requests.
Zaimki/pages/neutratywy.vue

395 lines
15 KiB
Vue
Raw Normal View History

2020-08-04 07:15:41 -07:00
<template>
<div class="container">
<Homepage/>
2020-08-04 07:15:41 -07:00
<h1>
<Icon v="atom-alt"/>
Słownik neutratywów
</h1>
<section>
<p>
Feminatywy feminatywami, ale prawdziwe wyzwanie to tworzenie neutratywów!
</p>
<p>
Poniżej przedstawiamy tworzony przez społeczność słownik rzeczowników
z wyszczególnieniem ich formy męskiej, żeńskiej i neutralnej.
</p>
<div class="alert alert-info small">
<p>
<strong>Czym neutratywy?</strong>
</p>
<p>
to słowa ukute na nijakie wersje słów nacechowanych płciowo, analogicznie do feminatywów, czyli wersji żeńskich.
</p>
<p>
<strong>Dlaczego warto tworzyć neutratywy?</strong>
</p>
<p>
Z tych samych powodów co feminatywy!
</p>
<p>
O ile łatwiej byłoby, gdyby nazwy zawodów zatraciły swoje często męskie nacechowanie.
Niestety tak się nie dzieje, przez co domyślnie możemy określać płeć osoby wykonującej ten zawód jako męską.
</p>
<p>
Jednak nie każda osoba chce używać zaimków i form męskich czy żeńskich,
choćby dlatego, że płeć człowieka wymyka się tym dwóm kategoriom.
Coraz więcej osób używa w odniesieniu do siebie
<nuxt-link to="/ono">rodzaju nijakiego</nuxt-link> i <nuxt-link to="/">innych form</nuxt-link>.
Formy te zaczynają być także potrzebne w tłumaczeniach z języków,
gdzie używane formy niebinarne takie jak choćby angielskie zaimki they/them.
Z tego powodu proponujemy rozbudowę niebinarnej polszczyzny poprzez wspólne tworzenie form nijakich.
</p>
2020-08-25 14:43:47 -07:00
<p>
<Icon v="radio"/>
<a href="https://pod.co/haloradio/joanna-frejus-2020-08-23-17-00" target="_blank" rel="noopener">
Osoby redaktorskie Słownika Neutratywów u Joanny Frejus w Halo.Radio
</a>
</p>
</div>
2020-08-04 07:15:41 -07:00
<p>
Aby dodać swoją propozycję:
2020-08-05 13:10:37 -07:00
<button class="btn btn-outline-success" @click="$refs.form.$el.scrollIntoView()">
2020-08-04 07:15:41 -07:00
<Icon v="plus-circle"/>
Formularz zgłoszeniowy
</button>
</p>
<p>
Obserwuj Słownik na Facebooku:
2020-08-05 13:10:37 -07:00
<a href="https://facebook.com/neutratywy" target="_blank" rel="noopener" class="btn btn-outline-info">
<Icon v="facebook" set="b"/>
fb.com/neutratywy
</a>
</p>
2020-08-04 07:15:41 -07:00
<p>
Dla form neutralnych innych niż rzeczowniki zapraszamy na
2020-08-05 13:10:37 -07:00
<nuxt-link to="/" class="btn btn-outline-primary">
2020-08-04 07:15:41 -07:00
<Icon v="tags"/>
Zaimki.pl
</nuxt-link>
</p>
<Share title="Słownik neutratywów"/>
</section>
<Separator icon="book-open"/>
2020-08-04 07:15:41 -07:00
<section v-if="secret">
<div class="alert alert-info">
2020-08-06 07:56:39 -07:00
<strong>{{ nounsCountApproved() }}</strong> wpisów zatwierdzonych,
<strong>{{ nounsCountPending() }}</strong> oczekuje na moderację.
</div>
</section>
2020-08-06 08:19:13 -07:00
<section class="sticky-top">
<div class="input-group mb-3 bg-white">
2020-08-06 06:33:38 -07:00
<div class="input-group-prepend">
<span class="input-group-text">
<Icon v="filter"/>
</span>
</div>
<input class="form-control border-primary" v-model="filter" placeholder="Filtruj listę…" ref="filter"/>
2020-08-06 06:33:38 -07:00
<div class="input-group-append" v-if="filter">
<button class="btn btn-outline-danger" @click="filter = ''; $refs.filter.focus()">
<Icon v="times"/>
</button>
</div>
2020-08-06 08:19:13 -07:00
<div class="input-group-append">
<button class="btn btn-outline-success" @click="$refs.form.$el.scrollIntoView()">
<Icon v="plus-circle"/>
Zgłoś
</button>
</div>
2020-08-06 06:33:38 -07:00
</div>
2020-08-04 07:15:41 -07:00
</section>
<section class="table-responsive">
<table :class="'table table-striped table-hover table-fixed-' + (secret ? 4 : 3)">
<thead>
<tr>
<th class="text-nowrap">
<Icon v="mars"/>
2020-08-20 08:02:03 -07:00
maskulatyw
2020-08-04 07:15:41 -07:00
</th>
<th class="text-nowrap">
<Icon v="venus"/>
feminatyw
</th>
<th class="text-nowrap">
<Icon v="neuter"/>
neutratyw
</th>
<th v-if="secret"></th>
</tr>
</thead>
<tbody>
2020-08-06 07:56:39 -07:00
<template v-if="visibleNouns().length">
<tr v-for="noun in visibleNouns()" :class="{'mark-left': !noun.approved}">
2020-08-04 07:15:41 -07:00
<td>
<ul class="list-singular">
<li v-for="w in noun.masc">{{ w }}</li>
</ul>
<ul class="list-plural">
<li v-for="w in noun.mascPl">{{ w }}</li>
</ul>
2020-08-05 10:14:46 -07:00
<small v-if="noun.base && nouns[noun.base]">
2020-08-22 07:01:47 -07:00
<p><strong>Propozycja zmiany z:</strong></p>
2020-08-04 07:15:41 -07:00
<ul class="list-singular">
<li v-for="w in nouns[noun.base].masc">{{ w }}</li>
</ul>
<ul class="list-plural">
<li v-for="w in nouns[noun.base].mascPl">{{ w }}</li>
</ul>
</small>
<button v-if="!secret" class="btn btn-outline-primary btn-sm m-1 hover-show" @click="edit(noun)">
2020-08-04 07:15:41 -07:00
<Icon v="pen"/>
Zaproponuj zmianę
</button>
</td>
<td>
<ul class="list-singular">
<li v-for="w in noun.fem">{{ w }}</li>
</ul>
<ul class="list-plural">
<li v-for="w in noun.femPl">{{ w }}</li>
</ul>
2020-08-05 10:14:46 -07:00
<small v-if="noun.base && nouns[noun.base]">
2020-08-22 07:01:47 -07:00
<p><strong>Propozycja zmiany z:</strong></p>
2020-08-04 07:15:41 -07:00
<ul class="list-singular">
<li v-for="w in nouns[noun.base].fem">{{ w }}</li>
</ul>
<ul class="list-plural">
<li v-for="w in nouns[noun.base].femPl">{{ w }}</li>
</ul>
</small>
</td>
<td>
<ul class="list-singular">
<li v-for="w in noun.neutr">{{ w }}</li>
</ul>
<ul class="list-plural">
<li v-for="w in noun.neutrPl">{{ w }}</li>
</ul>
2020-08-05 10:14:46 -07:00
<small v-if="noun.base && nouns[noun.base]">
2020-08-22 07:01:47 -07:00
<p><strong>Propozycja zmiany z:</strong></p>
2020-08-04 07:15:41 -07:00
<ul class="list-singular">
<li v-for="w in nouns[noun.base].neutr">{{ w }}</li>
</ul>
<ul class="list-plural">
<li v-for="w in nouns[noun.base].neutrPl">{{ w }}</li>
</ul>
</small>
</td>
<td v-if="secret">
<ul class="list-unstyled">
<li v-if="!noun.approved">
<button class="btn btn-success btn-sm m-1" @click="approve(noun)">
<Icon v="check"/>
Zatwierdź
</button>
</li>
<li v-else @click="hide(noun)">
<button class="btn btn-outline-secondary btn-sm m-1">
<Icon v="times"/>
Schowaj
</button>
</li>
<li>
<button class="btn btn-outline-danger btn-sm m-1" @click="remove(noun)">
<Icon v="trash"/>
Usuń
</button>
</li>
<li>
<button class="btn btn-outline-primary btn-sm m-1" @click="edit(noun)">
2020-08-04 07:15:41 -07:00
<Icon v="pen"/>
Edytuj
</button>
</li>
</ul>
</td>
</tr>
2020-08-06 06:33:38 -07:00
</template>
<template v-else>
<tr>
<td :colspan="secret ? 4 : 3" class="text-center">
<Icon v="search"/>
Nie znaleziono słów spełniających podane kryterium.
</td>
</tr>
</template>
2020-08-04 07:15:41 -07:00
</tbody>
</table>
</section>
<Separator icon="plus"/>
2020-08-04 07:15:41 -07:00
<NounSubmitForm ref="form" :secret="secret"/>
2020-09-04 08:51:26 -07:00
<ScrollButton colour="#0F3974"/>
2020-08-04 07:15:41 -07:00
</div>
</template>
<script>
import { Noun } from "~/src/classes";
import { buildDict } from "../src/helpers";
export default {
data() {
return {
filter: '',
nounsRaw: [],
secret: this.$route.query.secret,
}
},
async asyncData({app, route}) {
return {
nounsRaw: await app.$axios.$get(`/nouns/all?secret=${route.query.secret || ''}`),
};
},
2020-08-05 03:04:31 -07:00
mounted() {
if (process.client && window.location.hash) {
this.filter = window.location.hash.substr(1);
2020-08-06 07:56:39 -07:00
this.$refs.filter.focus();
this.$refs.filter.scrollIntoView();
2020-08-05 03:04:31 -07:00
setTimeout(_ => {
this.$refs.filter.scrollIntoView();
}, 1000);
}
},
2020-08-04 07:15:41 -07:00
methods: {
edit(noun) {
this.$refs.form.edit(noun);
},
async approve(noun) {
await this.$axios.$post(`/nouns/approve/${noun.id}?secret=${this.secret || ''}`);
if (noun.base) {
delete this.nouns[noun.base];
}
noun.approved = true;
noun.base = null;
this.$forceUpdate();
},
async hide(noun) {
await this.$axios.$post(`/nouns/hide/${noun.id}?secret=${this.secret || ''}`);
noun.approved = false;
this.$forceUpdate();
},
async remove(noun) {
if (!confirm('Czy na pewno usunąć ten wpis?')) {
return false;
}
await this.$axios.$post(`/nouns/remove/${noun.id}?secret=${this.secret || ''}`);
delete this.nouns[noun.id];
this.$forceUpdate();
},
2020-08-06 06:33:38 -07:00
visibleNouns() {
return Object.values(this.nouns).filter(n => n.matches(this.filter));
},
nounsCountApproved() {
return Object.values(this.nouns).filter(n => n.approved).length;
},
nounsCountPending() {
return Object.values(this.nouns).filter(n => !n.approved).length;
},
2020-08-04 07:15:41 -07:00
},
2020-08-06 07:56:39 -07:00
computed: {
nouns() {
return buildDict(function* (that) {
const sorted = that.nounsRaw.sort((a, b) => {
if (a.approved && !b.approved) {
return 1;
}
if (!a.approved && b.approved) {
return -1;
}
return a.masc.toLowerCase().localeCompare(b.masc.toLowerCase());
});
for (let w of sorted) {
2020-08-06 07:56:39 -07:00
yield [w.id, new Noun(w)];
}
}, this);
},
},
2020-08-05 03:04:31 -07:00
watch: {
filter() {
if (process.client) {
if (this.filter) {
window.location.hash = this.filter;
} else {
history.pushState('', document.title, window.location.pathname + window.location.search);
}
}
}
},
2020-08-04 07:15:41 -07:00
head() {
const title = 'Słownik neutratywów';
2020-08-05 12:21:47 -07:00
const description = 'Feminatywy feminatywami, ale prawdziwe wyzwanie to tworzenie neutratywów! Przedstawiamy tworzony przez społeczność słownik rzeczowników z wyszczególnieniem ich formy męskiej, żeńskiej i neutralnej.';
2020-08-04 07:15:41 -07:00
const banner = `${process.env.baseUrl}/bannerNouns.png`;
return {
title: title,
meta: [
{ hid: 'og:title', property: 'og:title', content: title },
{ hid: 'twitter:title', property: 'twitter:title', content: title },
2020-08-05 12:21:47 -07:00
{ hid: 'description', name: 'description', content: description },
{ hid: 'og:description', property: 'og:description', content: description },
{ hid: 'twitter:description', property: 'twitter:description', content: description },
2020-08-04 07:15:41 -07:00
{ hid: 'og:logo', property: 'og:logo', content: banner },
{ hid: 'twitter:image', property: 'twitter:image', content: banner },
],
}
},
}
</script>
<style lang="scss">
@import "assets/style";
.list-singular {
padding-left: 0;
list-style: none;
li {
white-space: nowrap;
}
li:before {
content: "⋅";
display: inline-block;
width: $fa-fw-width;
text-align: center;
}
}
.list-plural {
padding-left: 0;
list-style: none;
li {
white-space: nowrap;
}
li:before {
content: "⁖";
display: inline-block;
width: $fa-fw-width;
text-align: center;
}
}
.mark-left {
border-left: 3px solid $primary;
2020-08-04 07:15:41 -07:00
}
tr {
.hover-show {
opacity: 0;
}
&:hover .hover-show {
opacity: 1;
}
}
</style>