mirror of
https://gitlab.com/Chill-Projet/chill-bundles.git
synced 2025-10-09 14:59:43 +00:00
Compare commits
3 Commits
upgrade-ph
...
58-birthda
Author | SHA1 | Date | |
---|---|---|---|
a136a278da
|
|||
9c85ad74ce | |||
fec2dd0f74 |
@@ -2,20 +2,11 @@
|
|||||||
|
|
||||||
<!-- https://phpunit.readthedocs.io/en/latest/configuration.html -->
|
<!-- https://phpunit.readthedocs.io/en/latest/configuration.html -->
|
||||||
<phpunit xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
|
<phpunit xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
|
||||||
xsi:noNamespaceSchemaLocation="https://schema.phpunit.de/9.6/phpunit.xsd"
|
xsi:noNamespaceSchemaLocation="tests/app/vendor/phpunit/phpunit/phpunit.xsd"
|
||||||
backupGlobals="false"
|
backupGlobals="false"
|
||||||
colors="true"
|
colors="true"
|
||||||
bootstrap="tests/app/tests/bootstrap.php"
|
bootstrap="tests/app/tests/bootstrap.php"
|
||||||
cacheResultFile=".phpunit.cache/test-results"
|
>
|
||||||
executionOrder="depends,defects"
|
|
||||||
forceCoversAnnotation="true"
|
|
||||||
beStrictAboutCoversAnnotation="true"
|
|
||||||
beStrictAboutOutputDuringTests="true"
|
|
||||||
beStrictAboutTodoAnnotatedTests="true"
|
|
||||||
convertDeprecationsToExceptions="true"
|
|
||||||
failOnRisky="true"
|
|
||||||
failOnWarning="true"
|
|
||||||
verbose="true">
|
|
||||||
<php>
|
<php>
|
||||||
<ini name="error_reporting" value="-1" />
|
<ini name="error_reporting" value="-1" />
|
||||||
<server name="APP_ENV" value="test" force="true" />
|
<server name="APP_ENV" value="test" force="true" />
|
||||||
|
@@ -1,90 +1,52 @@
|
|||||||
<template>
|
<template>
|
||||||
<a v-if="!state.is_ready" :class="props.classes" @click="download_and_open($event)">
|
<a :class="props.classes" @click="download_and_open($event)">
|
||||||
<i class="fa fa-download"></i>
|
<i class="fa fa-download"></i>
|
||||||
Télécharger
|
Télécharger
|
||||||
</a>
|
</a>
|
||||||
<a v-else :class="props.classes" target="_blank" :type="props.storedObject.type" :download="buildDocumentName()" :href="state.href_url" ref="open_button">
|
|
||||||
<i class="fa fa-external-link"></i>
|
|
||||||
Ouvrir
|
|
||||||
</a>
|
|
||||||
</template>
|
</template>
|
||||||
|
|
||||||
<script lang="ts" setup>
|
<script lang="ts" setup>
|
||||||
import {reactive, ref, nextTick, onMounted} from "vue";
|
import {reactive} from "vue";
|
||||||
import {build_download_info_link, download_and_decrypt_doc} from "./helpers";
|
import {build_download_info_link, download_and_decrypt_doc} from "./helpers";
|
||||||
import mime from "mime";
|
import mime from "mime";
|
||||||
import {StoredObject} from "../../types";
|
import {StoredObject} from "../../types";
|
||||||
|
|
||||||
interface DownloadButtonConfig {
|
interface DownloadButtonConfig {
|
||||||
storedObject: StoredObject,
|
storedObject: StoredObject,
|
||||||
classes: { [k: string]: boolean },
|
classes: {[k: string]: boolean},
|
||||||
filename?: string,
|
filename?: string,
|
||||||
}
|
}
|
||||||
|
|
||||||
interface DownloadButtonState {
|
interface DownloadButtonState {
|
||||||
is_ready: boolean,
|
is_ready: boolean
|
||||||
is_running: boolean,
|
|
||||||
href_url: string,
|
|
||||||
}
|
}
|
||||||
|
|
||||||
const props = defineProps<DownloadButtonConfig>();
|
const props = defineProps<DownloadButtonConfig>();
|
||||||
const state: DownloadButtonState = reactive({is_ready: false, is_running: false, href_url: "#"});
|
const state: DownloadButtonState = reactive({is_ready: false});
|
||||||
|
|
||||||
const open_button = ref<HTMLAnchorElement | null>(null);
|
|
||||||
|
|
||||||
function buildDocumentName(): string {
|
|
||||||
const document_name = props.filename || 'document';
|
|
||||||
const ext = mime.getExtension(props.storedObject.type);
|
|
||||||
|
|
||||||
if (null !== ext) {
|
|
||||||
return document_name + '.' + ext;
|
|
||||||
}
|
|
||||||
|
|
||||||
return document_name;
|
|
||||||
}
|
|
||||||
|
|
||||||
async function download_and_open(event: Event): Promise<void> {
|
async function download_and_open(event: Event): Promise<void> {
|
||||||
const button = event.target as HTMLAnchorElement;
|
const button = event.target as HTMLAnchorElement;
|
||||||
|
|
||||||
if (state.is_running) {
|
|
||||||
console.log('state is running, aborting');
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
state.is_running = true;
|
|
||||||
|
|
||||||
if (state.is_ready) {
|
|
||||||
console.log('state is ready. This should not happens');
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
if (!state.is_ready) {
|
||||||
|
event.preventDefault();
|
||||||
const urlInfo = build_download_info_link(props.storedObject.filename);
|
const urlInfo = build_download_info_link(props.storedObject.filename);
|
||||||
let raw;
|
|
||||||
|
|
||||||
try {
|
const raw = await download_and_decrypt_doc(urlInfo, props.storedObject.keyInfos, new Uint8Array(props.storedObject.iv));
|
||||||
raw = await download_and_decrypt_doc(urlInfo, props.storedObject.keyInfos, new Uint8Array(props.storedObject.iv));
|
|
||||||
} catch (e) {
|
button.href = window.URL.createObjectURL(raw);
|
||||||
console.error("error while downloading and decrypting document");
|
button.target = '_blank';
|
||||||
console.error(e);
|
button.type = props.storedObject.type;
|
||||||
throw e;
|
|
||||||
|
button.download = props.filename || 'document';
|
||||||
|
|
||||||
|
const ext = mime.getExtension(props.storedObject.type);
|
||||||
|
if (null !== ext) {
|
||||||
|
button.download = button.download + '.' + ext;
|
||||||
}
|
}
|
||||||
|
|
||||||
console.log('document downloading (and decrypting) successfully');
|
|
||||||
|
|
||||||
console.log('creating the url')
|
|
||||||
state.href_url = window.URL.createObjectURL(raw);
|
|
||||||
console.log('url created', state.href_url);
|
|
||||||
state.is_running = false;
|
|
||||||
state.is_ready = true;
|
state.is_ready = true;
|
||||||
console.log('new button marked as ready');
|
|
||||||
console.log('will click on button');
|
|
||||||
|
|
||||||
console.log('openbutton is now', open_button.value);
|
button.click();
|
||||||
|
}
|
||||||
await nextTick();
|
|
||||||
console.log('next tick actions');
|
|
||||||
console.log('openbutton after next tick', open_button.value);
|
|
||||||
open_button.value?.click();
|
|
||||||
console.log('open button should have been clicked');
|
|
||||||
}
|
}
|
||||||
</script>
|
</script>
|
||||||
|
@@ -149,21 +149,16 @@ async function download_and_decrypt_doc(urlGenerator: string, keyData: JsonWebKe
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (iv.length === 0) {
|
if (iv.length === 0) {
|
||||||
console.log('returning document immediatly');
|
|
||||||
return rawResponse.blob();
|
return rawResponse.blob();
|
||||||
}
|
}
|
||||||
|
|
||||||
console.log('start decrypting doc');
|
|
||||||
|
|
||||||
const rawBuffer = await rawResponse.arrayBuffer();
|
const rawBuffer = await rawResponse.arrayBuffer();
|
||||||
|
|
||||||
try {
|
try {
|
||||||
const key = await window.crypto.subtle
|
const key = await window.crypto.subtle
|
||||||
.importKey('jwk', keyData, { name: algo }, false, ['decrypt']);
|
.importKey('jwk', keyData, { name: algo }, false, ['decrypt']);
|
||||||
console.log('key created');
|
|
||||||
const decrypted = await window.crypto.subtle
|
const decrypted = await window.crypto.subtle
|
||||||
.decrypt({ name: algo, iv: iv }, key, rawBuffer);
|
.decrypt({ name: algo, iv: iv }, key, rawBuffer);
|
||||||
console.log('doc decrypted');
|
|
||||||
|
|
||||||
return Promise.resolve(new Blob([decrypted]));
|
return Promise.resolve(new Blob([decrypted]));
|
||||||
} catch (e) {
|
} catch (e) {
|
||||||
|
@@ -51,10 +51,7 @@ class UserRefEventSubscriber implements EventSubscriberInterface
|
|||||||
|
|
||||||
public function onStateEntered(EnteredEvent $enteredEvent): void
|
public function onStateEntered(EnteredEvent $enteredEvent): void
|
||||||
{
|
{
|
||||||
if (
|
if ($enteredEvent->getMarking()->has(AccompanyingPeriod::STEP_CONFIRMED)) {
|
||||||
$enteredEvent->getMarking()->has(AccompanyingPeriod::STEP_CONFIRMED)
|
|
||||||
and $enteredEvent->getTransition()->getName() === 'confirm'
|
|
||||||
) {
|
|
||||||
$this->onPeriodConfirmed($enteredEvent->getSubject());
|
$this->onPeriodConfirmed($enteredEvent->getSubject());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@@ -207,7 +207,7 @@
|
|||||||
</template>
|
</template>
|
||||||
|
|
||||||
<script>
|
<script>
|
||||||
import {dateToISO} from 'ChillMainAssets/chill/js/date';
|
import {dateToISO, ISOToDate} from 'ChillMainAssets/chill/js/date';
|
||||||
import AddressRenderBox from 'ChillMainAssets/vuejs/_components/Entity/AddressRenderBox.vue';
|
import AddressRenderBox from 'ChillMainAssets/vuejs/_components/Entity/AddressRenderBox.vue';
|
||||||
import Confidential from 'ChillMainAssets/vuejs/_components/Confidential.vue';
|
import Confidential from 'ChillMainAssets/vuejs/_components/Confidential.vue';
|
||||||
import BadgeEntity from 'ChillMainAssets/vuejs/_components/BadgeEntity.vue';
|
import BadgeEntity from 'ChillMainAssets/vuejs/_components/BadgeEntity.vue';
|
||||||
@@ -262,7 +262,7 @@ export default {
|
|||||||
},
|
},
|
||||||
birthdate: function () {
|
birthdate: function () {
|
||||||
if (this.person.birthdate !== null || this.person.birthdate === "undefined") {
|
if (this.person.birthdate !== null || this.person.birthdate === "undefined") {
|
||||||
return new Date(this.person.birthdate.datetime);
|
return ISOToDate(this.person.birthdate.datetime);
|
||||||
} else {
|
} else {
|
||||||
return "";
|
return "";
|
||||||
}
|
}
|
||||||
|
@@ -16,13 +16,11 @@
|
|||||||
</div>
|
</div>
|
||||||
<div class="wh-col">
|
<div class="wh-col">
|
||||||
{% if period.step == 'DRAFT' %}
|
{% if period.step == 'DRAFT' %}
|
||||||
<span class="badge bg-secondary" style="font-size: 85%;" title="{{ 'course.draft'|trans|e('html_attr') }}">{{ 'course.draft'|trans }}</span>
|
<span class="badge bg-secondary">{{- 'Draft'|trans|upper -}}</span>
|
||||||
{% elseif period.step == 'CLOSED' %}
|
{% elseif period.step == 'CONFIRMED' %}
|
||||||
<span class="badge bg-danger" style="font-size: 85%;" title="{{ 'course.closed'|trans|e('html_attr') }}">{{ 'course.closed'|trans }}</span>
|
<span class="badge bg-primary">{{- 'Confirmed'|trans|upper -}}</span>
|
||||||
{% elseif period.step == 'CONFIRMED_INACTIVE_SHORT' %}
|
{% else %}
|
||||||
<span class="badge bg-chill-yellow text-primary" style="font-size: 85%;" title="{{ 'course.inactive_short'|trans|e('html_attr') }}">{{ 'course.inactive_short'|trans }}</span>
|
<span class="badge bg-danger">{{- 'Closed'|trans|upper -}}</span>
|
||||||
{% elseif period.step == 'CONFIRMED_INACTIVE_LONG' %}
|
|
||||||
<span class="badge bg-danger" style="font-size: 85%;" title="{{ 'course.inactive_long'|trans|e('html_attr') }}">{{ 'course.inactive_long'|trans }}</span>
|
|
||||||
{% endif %}
|
{% endif %}
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
Reference in New Issue
Block a user