feat(planning): grille hebdomadaire complète avec API et filtres
- Connexion API via proxy Angular (résolution CORS, base path /api) - Import CSS ng-zorro global pour les modales et composants - Filtres Camion/Show câblés sur l'affichage de la grille - Camions affichés via TrucksService (linkés au show du même créneau) - Panneau de détails : spectacles + camions du jour sélectionné - Modale de création de spectacle stylisée avec fond et centrage - Positionnement précis des events à la minute dans leur créneau - Auto-scroll vers l'heure courante au chargement - Ligne "maintenant" sur la colonne du jour actuel - Régénération des services OpenAPI (nouveaux noms de types) Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
This commit is contained in:
+2
-13
@@ -228,19 +228,8 @@ function serializeString({gen, data}: SerializeCxt): void {
|
||||
gen.add(N.json, _`${useFunc(gen, quote)}(${data})`)
|
||||
}
|
||||
|
||||
function serializeNumber({gen, data, self}: SerializeCxt): void {
|
||||
const condition = _`${data} === Infinity || ${data} === -Infinity || ${data} !== ${data}`
|
||||
|
||||
if (self.opts.specialNumbers === undefined || self.opts.specialNumbers === "fast") {
|
||||
gen.add(N.json, _`"" + ${data}`)
|
||||
} else {
|
||||
// specialNumbers === "null"
|
||||
gen.if(
|
||||
condition,
|
||||
() => gen.add(N.json, _`null`),
|
||||
() => gen.add(N.json, _`"" + ${data}`)
|
||||
)
|
||||
}
|
||||
function serializeNumber({gen, data}: SerializeCxt): void {
|
||||
gen.add(N.json, _`"" + ${data}`)
|
||||
}
|
||||
|
||||
function serializeRef(cxt: SerializeCxt): void {
|
||||
|
||||
-1
@@ -107,7 +107,6 @@ export interface CurrentOptions {
|
||||
timestamp?: "string" | "date" // JTD only
|
||||
parseDate?: boolean // JTD only
|
||||
allowDate?: boolean // JTD only
|
||||
specialNumbers?: "fast" | "null" // JTD only
|
||||
$comment?:
|
||||
| true
|
||||
| ((comment: string, schemaPath?: string, rootSchema?: AnySchemaObject) => unknown)
|
||||
|
||||
+4
-15
@@ -1,7 +1,6 @@
|
||||
import type {CodeKeywordDefinition, ErrorObject, KeywordErrorDefinition} from "../../types"
|
||||
import type {KeywordCxt} from "../../compile/validate"
|
||||
import {usePattern} from "../code"
|
||||
import {useFunc} from "../../compile/util"
|
||||
import {_, str} from "../../compile/codegen"
|
||||
|
||||
export type PatternError = ErrorObject<"pattern", {pattern: string}, string | {$data: string}>
|
||||
@@ -18,21 +17,11 @@ const def: CodeKeywordDefinition = {
|
||||
$data: true,
|
||||
error,
|
||||
code(cxt: KeywordCxt) {
|
||||
const {gen, data, $data, schema, schemaCode, it} = cxt
|
||||
const {data, $data, schema, schemaCode, it} = cxt
|
||||
// TODO regexp should be wrapped in try/catchs
|
||||
const u = it.opts.unicodeRegExp ? "u" : ""
|
||||
if ($data) {
|
||||
const {regExp} = it.opts.code
|
||||
const regExpCode = regExp.code === "new RegExp" ? _`new RegExp` : useFunc(gen, regExp)
|
||||
const valid = gen.let("valid")
|
||||
gen.try(
|
||||
() => gen.assign(valid, _`${regExpCode}(${schemaCode}, ${u}).test(${data})`),
|
||||
() => gen.assign(valid, false)
|
||||
)
|
||||
cxt.fail$data(_`!${valid}`)
|
||||
} else {
|
||||
const regExp = usePattern(cxt, schema)
|
||||
cxt.fail$data(_`!${regExp}.test(${data})`)
|
||||
}
|
||||
const regExp = $data ? _`(new RegExp(${schemaCode}, ${u}))` : usePattern(cxt, schema)
|
||||
cxt.fail$data(_`!${regExp}.test(${data})`)
|
||||
},
|
||||
}
|
||||
|
||||
|
||||
Reference in New Issue
Block a user