@ecodev/natural 45.0.1 → 45.1.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2020/lib/classes/utility.mjs +1 -6
- package/esm2020/lib/modules/dropdown-components/type-date/type-date.component.mjs +1 -1
- package/esm2020/lib/modules/dropdown-components/type-date-range/type-date-range.component.mjs +1 -1
- package/esm2020/lib/modules/dropdown-components/type-number/type-number.component.mjs +7 -3
- package/esm2020/lib/modules/dropdown-components/type-select/type-select.component.mjs +9 -5
- package/esm2020/lib/modules/fixed-button-detail/fixed-button-detail.component.mjs +8 -4
- package/esm2020/lib/modules/logger/error-handler.mjs +2 -4
- package/fesm2015/ecodev-natural.mjs +21 -18
- package/fesm2015/ecodev-natural.mjs.map +1 -1
- package/fesm2020/ecodev-natural.mjs +21 -18
- package/fesm2020/ecodev-natural.mjs.map +1 -1
- package/lib/classes/utility.d.ts +2 -0
- package/lib/modules/dropdown-components/type-date/type-date.component.d.ts +1 -1
- package/lib/modules/dropdown-components/type-date-range/type-date-range.component.d.ts +1 -1
- package/lib/modules/dropdown-components/type-number/type-number.component.d.ts +2 -1
- package/lib/modules/dropdown-components/type-select/type-select.component.d.ts +7 -3
- package/lib/modules/fixed-button-detail/fixed-button-detail.component.d.ts +2 -1
- package/package.json +1 -1
|
@@ -1,9 +1,4 @@
|
|
|
1
1
|
import { isArray, isEmpty, isObject, pickBy } from 'lodash-es';
|
|
2
|
-
/**
|
|
3
|
-
* Very basic formatting to get only date, without time and ignoring entirely the timezone
|
|
4
|
-
*
|
|
5
|
-
* So something like: "2021-09-23"
|
|
6
|
-
*/
|
|
7
2
|
export function formatIsoDate(date) {
|
|
8
3
|
if (!date) {
|
|
9
4
|
return null;
|
|
@@ -167,4 +162,4 @@ export function deepFreeze(o) {
|
|
|
167
162
|
Object.values(o).forEach(v => Object.isFrozen(v) || deepFreeze(v));
|
|
168
163
|
return Object.freeze(o);
|
|
169
164
|
}
|
|
170
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"utility.js","sourceRoot":"","sources":["../../../../../projects/natural/src/lib/classes/utility.ts"],"names":[],"mappings":"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","sourcesContent":["import {isArray, isEmpty, isObject, pickBy} from 'lodash-es';\nimport {Literal} from '../types/types';\nimport type {ReadonlyDeep} from 'type-fest';\n\n/**\n * Very basic formatting to get only date, without time and ignoring entirely the timezone\n *\n * So something like: \"2021-09-23\"\n */\nexport function formatIsoDate(date: Date | null): string | null {\n    if (!date) {\n        return null;\n    }\n\n    const y = date.getFullYear();\n    const m = date.getMonth() + 1;\n    const d = date.getDate();\n\n    return y + '-' + (m < 10 ? '0' : '') + m + '-' + (d < 10 ? '0' : '') + d;\n}\n\n/**\n * Format a date and time in a way that will preserve the local time zone.\n * This allow the server side to know the day (without time) that was selected on client side.\n *\n * So something like: \"2021-09-23T17:57:16+09:00\"\n */\nexport function formatIsoDateTime(date: Date): string {\n    const timezoneOffsetInMinutes = date.getTimezoneOffset();\n    const timezoneOffsetInHours = -Math.trunc(timezoneOffsetInMinutes / 60); // UTC minus local time\n    const sign = timezoneOffsetInHours >= 0 ? '+' : '-';\n    const hoursLeadingZero = Math.abs(timezoneOffsetInHours) < 10 ? '0' : '';\n    const remainderMinutes = -(timezoneOffsetInMinutes % 60);\n    const minutesLeadingZero = Math.abs(remainderMinutes) < 10 ? '0' : '';\n\n    // It's a bit unfortunate that we need to construct a new Date instance,\n    // but we don't want the original Date instance to be modified\n    const correctedDate = new Date(\n        date.getFullYear(),\n        date.getMonth(),\n        date.getDate(),\n        date.getHours(),\n        date.getMinutes(),\n        date.getSeconds(),\n        date.getMilliseconds(),\n    );\n    correctedDate.setHours(date.getHours() + timezoneOffsetInHours);\n\n    const iso = correctedDate\n        .toISOString()\n        .replace(/\\.\\d{3}Z/, '')\n        .replace('Z', '');\n\n    return (\n        iso +\n        sign +\n        hoursLeadingZero +\n        Math.abs(timezoneOffsetInHours).toString() +\n        ':' +\n        minutesLeadingZero +\n        remainderMinutes\n    );\n}\n\n/**\n * Relations to full objects are converted to their IDs only.\n *\n * So {user: {id: 123}} becomes {user: 123}\n */\nexport function relationsToIds(object: Literal): Literal {\n    const newObj: Literal = {};\n    Object.keys(object).forEach(key => {\n        let value: string | Literal = object[key];\n        if (isObject(value) && value.id) {\n            value = value.id;\n        } else if (isArray(value)) {\n            value = value.map((i: string | Literal) => (isObject(i) && i.id ? i.id : i));\n        } else if (isObject(value) && !(value instanceof File) && !(value instanceof Date)) {\n            value = pickBy(value, (v, k) => k !== '__typename'); // omit(value, ['__typename']) ?\n        }\n\n        newObj[key] = value;\n    });\n\n    return newObj;\n}\n\n/**\n * Remove from source object the attributes with same value as modified\n * Does not consider arrays\n */\nexport function cleanSameValues(source: Literal, modified: Literal): Literal {\n    Object.keys(source).forEach(key => {\n        if (source[key] instanceof Object) {\n            cleanSameValues(source[key], modified[key]);\n            if (isEmpty(source[key])) {\n                delete source[key];\n            }\n        } else if (modified && source[key] === modified[key]) {\n            delete source[key];\n        }\n    });\n\n    return source;\n}\n\n/**\n * Returns the plural form of the given name\n */\nexport function makePlural(name: string): string {\n    const plural = name + 's';\n\n    return plural.replace(/ys$/, 'ies').replace(/ss$/, 'ses').replace(/xs$/, 'xes');\n}\n\n/**\n * Returns the string with the first letter as capital\n */\nexport function upperCaseFirstLetter(term: string): string {\n    return term.charAt(0).toUpperCase() + term.slice(1);\n}\n\n/**\n * Returns the string with the first letter as lower case\n */\nexport function lowerCaseFirstLetter(term: string): string {\n    return term.charAt(0).toLowerCase() + term.slice(1);\n}\n\n/**\n * Replace all attributes of first object with the ones provided by the second, but keeps the reference\n */\nexport function replaceObjectKeepingReference(obj: Literal | null, newObj: Literal | null): void {\n    if (!obj || !newObj) {\n        return;\n    }\n\n    Object.keys(obj).forEach(key => {\n        delete obj[key];\n    });\n\n    Object.keys(newObj).forEach(key => {\n        obj[key] = newObj[key];\n    });\n}\n\n/**\n * Get contrasted color for text in the slider thumb\n * @param hexBgColor string in hexadecimals representing the background color\n */\nexport function getForegroundColor(hexBgColor: string): 'black' | 'white' {\n    const rgb = hexToRgb(hexBgColor.slice(0, 7)); // splice remove alpha and consider only \"visible\" color at 100% alpha\n    const o = Math.round((rgb.r * 299 + rgb.g * 587 + rgb.b * 114) / 1000);\n\n    return o > 125 ? 'black' : 'white';\n}\n\nfunction hexToRgb(hex: string): {r: number; g: number; b: number} {\n    // Expand shorthand form (e.g. \"03F\") to full form (e.g. \"0033FF\")\n    const shorthandRegex = /^#?([a-f\\d])([a-f\\d])([a-f\\d])$/i;\n    hex = hex.replace(shorthandRegex, (m, r, g, b) => {\n        return r + r + g + g + b + b;\n    });\n\n    const result = /^#?([a-f\\d]{2})([a-f\\d]{2})([a-f\\d]{2})$/i.exec(hex);\n    return result\n        ? {\n              r: parseInt(result[1], 16),\n              g: parseInt(result[2], 16),\n              b: parseInt(result[3], 16),\n          }\n        : {\n              r: 0,\n              g: 0,\n              b: 0,\n          };\n}\n\n/**\n * During lodash.mergeWith, overrides arrays\n */\nexport function mergeOverrideArray(destValue: any, source: any): any {\n    if (isArray(source)) {\n        return source;\n    }\n}\n\n/**\n * Copy text to clipboard.\n * Accepts line breaks `\\n` as textarea do.\n */\nexport function copyToClipboard(document: Document, text: string): void {\n    const input = document.createElement('textarea');\n    document.body.append(input);\n    input.value = text;\n    input.select();\n    document.execCommand('copy');\n    document.body.removeChild(input);\n}\n\nexport function deepFreeze<T>(o: T): ReadonlyDeep<T> {\n    Object.values(o).forEach(v => Object.isFrozen(v) || deepFreeze(v));\n\n    return Object.freeze(o) as ReadonlyDeep<T>;\n}\n"]}
|
|
165
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"utility.js","sourceRoot":"","sources":["../../../../../projects/natural/src/lib/classes/utility.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,OAAO,EAAE,OAAO,EAAE,QAAQ,EAAE,MAAM,EAAC,MAAM,WAAW,CAAC;AAY7D,MAAM,UAAU,aAAa,CAAC,IAAiB;IAC3C,IAAI,CAAC,IAAI,EAAE;QACP,OAAO,IAAI,CAAC;KACf;IAED,MAAM,CAAC,GAAG,IAAI,CAAC,WAAW,EAAE,CAAC;IAC7B,MAAM,CAAC,GAAG,IAAI,CAAC,QAAQ,EAAE,GAAG,CAAC,CAAC;IAC9B,MAAM,CAAC,GAAG,IAAI,CAAC,OAAO,EAAE,CAAC;IAEzB,OAAO,CAAC,GAAG,GAAG,GAAG,CAAC,CAAC,GAAG,EAAE,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,GAAG,CAAC,GAAG,GAAG,GAAG,CAAC,CAAC,GAAG,EAAE,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC;AAC7E,CAAC;AAED;;;;;GAKG;AACH,MAAM,UAAU,iBAAiB,CAAC,IAAU;IACxC,MAAM,uBAAuB,GAAG,IAAI,CAAC,iBAAiB,EAAE,CAAC;IACzD,MAAM,qBAAqB,GAAG,CAAC,IAAI,CAAC,KAAK,CAAC,uBAAuB,GAAG,EAAE,CAAC,CAAC,CAAC,uBAAuB;IAChG,MAAM,IAAI,GAAG,qBAAqB,IAAI,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC;IACpD,MAAM,gBAAgB,GAAG,IAAI,CAAC,GAAG,CAAC,qBAAqB,CAAC,GAAG,EAAE,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC;IACzE,MAAM,gBAAgB,GAAG,CAAC,CAAC,uBAAuB,GAAG,EAAE,CAAC,CAAC;IACzD,MAAM,kBAAkB,GAAG,IAAI,CAAC,GAAG,CAAC,gBAAgB,CAAC,GAAG,EAAE,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC;IAEtE,wEAAwE;IACxE,8DAA8D;IAC9D,MAAM,aAAa,GAAG,IAAI,IAAI,CAC1B,IAAI,CAAC,WAAW,EAAE,EAClB,IAAI,CAAC,QAAQ,EAAE,EACf,IAAI,CAAC,OAAO,EAAE,EACd,IAAI,CAAC,QAAQ,EAAE,EACf,IAAI,CAAC,UAAU,EAAE,EACjB,IAAI,CAAC,UAAU,EAAE,EACjB,IAAI,CAAC,eAAe,EAAE,CACzB,CAAC;IACF,aAAa,CAAC,QAAQ,CAAC,IAAI,CAAC,QAAQ,EAAE,GAAG,qBAAqB,CAAC,CAAC;IAEhE,MAAM,GAAG,GAAG,aAAa;SACpB,WAAW,EAAE;SACb,OAAO,CAAC,UAAU,EAAE,EAAE,CAAC;SACvB,OAAO,CAAC,GAAG,EAAE,EAAE,CAAC,CAAC;IAEtB,OAAO,CACH,GAAG;QACH,IAAI;QACJ,gBAAgB;QAChB,IAAI,CAAC,GAAG,CAAC,qBAAqB,CAAC,CAAC,QAAQ,EAAE;QAC1C,GAAG;QACH,kBAAkB;QAClB,gBAAgB,CACnB,CAAC;AACN,CAAC;AAED;;;;GAIG;AACH,MAAM,UAAU,cAAc,CAAC,MAAe;IAC1C,MAAM,MAAM,GAAY,EAAE,CAAC;IAC3B,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,GAAG,CAAC,EAAE;QAC9B,IAAI,KAAK,GAAqB,MAAM,CAAC,GAAG,CAAC,CAAC;QAC1C,IAAI,QAAQ,CAAC,KAAK,CAAC,IAAI,KAAK,CAAC,EAAE,EAAE;YAC7B,KAAK,GAAG,KAAK,CAAC,EAAE,CAAC;SACpB;aAAM,IAAI,OAAO,CAAC,KAAK,CAAC,EAAE;YACvB,KAAK,GAAG,KAAK,CAAC,GAAG,CAAC,CAAC,CAAmB,EAAE,EAAE,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;SAChF;aAAM,IAAI,QAAQ,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,KAAK,YAAY,IAAI,CAAC,IAAI,CAAC,CAAC,KAAK,YAAY,IAAI,CAAC,EAAE;YAChF,KAAK,GAAG,MAAM,CAAC,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,KAAK,YAAY,CAAC,CAAC,CAAC,gCAAgC;SACxF;QAED,MAAM,CAAC,GAAG,CAAC,GAAG,KAAK,CAAC;IACxB,CAAC,CAAC,CAAC;IAEH,OAAO,MAAM,CAAC;AAClB,CAAC;AAED;;;GAGG;AACH,MAAM,UAAU,eAAe,CAAC,MAAe,EAAE,QAAiB;IAC9D,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,GAAG,CAAC,EAAE;QAC9B,IAAI,MAAM,CAAC,GAAG,CAAC,YAAY,MAAM,EAAE;YAC/B,eAAe,CAAC,MAAM,CAAC,GAAG,CAAC,EAAE,QAAQ,CAAC,GAAG,CAAC,CAAC,CAAC;YAC5C,IAAI,OAAO,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,EAAE;gBACtB,OAAO,MAAM,CAAC,GAAG,CAAC,CAAC;aACtB;SACJ;aAAM,IAAI,QAAQ,IAAI,MAAM,CAAC,GAAG,CAAC,KAAK,QAAQ,CAAC,GAAG,CAAC,EAAE;YAClD,OAAO,MAAM,CAAC,GAAG,CAAC,CAAC;SACtB;IACL,CAAC,CAAC,CAAC;IAEH,OAAO,MAAM,CAAC;AAClB,CAAC;AAED;;GAEG;AACH,MAAM,UAAU,UAAU,CAAC,IAAY;IACnC,MAAM,MAAM,GAAG,IAAI,GAAG,GAAG,CAAC;IAE1B,OAAO,MAAM,CAAC,OAAO,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC,OAAO,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC,OAAO,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC;AACpF,CAAC;AAED;;GAEG;AACH,MAAM,UAAU,oBAAoB,CAAC,IAAY;IAC7C,OAAO,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,WAAW,EAAE,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;AACxD,CAAC;AAED;;GAEG;AACH,MAAM,UAAU,oBAAoB,CAAC,IAAY;IAC7C,OAAO,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,WAAW,EAAE,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;AACxD,CAAC;AAED;;GAEG;AACH,MAAM,UAAU,6BAA6B,CAAC,GAAmB,EAAE,MAAsB;IACrF,IAAI,CAAC,GAAG,IAAI,CAAC,MAAM,EAAE;QACjB,OAAO;KACV;IAED,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,OAAO,CAAC,GAAG,CAAC,EAAE;QAC3B,OAAO,GAAG,CAAC,GAAG,CAAC,CAAC;IACpB,CAAC,CAAC,CAAC;IAEH,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,GAAG,CAAC,EAAE;QAC9B,GAAG,CAAC,GAAG,CAAC,GAAG,MAAM,CAAC,GAAG,CAAC,CAAC;IAC3B,CAAC,CAAC,CAAC;AACP,CAAC;AAED;;;GAGG;AACH,MAAM,UAAU,kBAAkB,CAAC,UAAkB;IACjD,MAAM,GAAG,GAAG,QAAQ,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,sEAAsE;IACpH,MAAM,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,GAAG,GAAG,GAAG,CAAC,CAAC,GAAG,GAAG,GAAG,GAAG,CAAC,CAAC,GAAG,GAAG,CAAC,GAAG,IAAI,CAAC,CAAC;IAEvE,OAAO,CAAC,GAAG,GAAG,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,OAAO,CAAC;AACvC,CAAC;AAED,SAAS,QAAQ,CAAC,GAAW;IACzB,kEAAkE;IAClE,MAAM,cAAc,GAAG,kCAAkC,CAAC;IAC1D,GAAG,GAAG,GAAG,CAAC,OAAO,CAAC,cAAc,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,EAAE;QAC7C,OAAO,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;IACjC,CAAC,CAAC,CAAC;IAEH,MAAM,MAAM,GAAG,2CAA2C,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;IACrE,OAAO,MAAM;QACT,CAAC,CAAC;YACI,CAAC,EAAE,QAAQ,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC;YAC1B,CAAC,EAAE,QAAQ,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC;YAC1B,CAAC,EAAE,QAAQ,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC;SAC7B;QACH,CAAC,CAAC;YACI,CAAC,EAAE,CAAC;YACJ,CAAC,EAAE,CAAC;YACJ,CAAC,EAAE,CAAC;SACP,CAAC;AACZ,CAAC;AAED;;GAEG;AACH,MAAM,UAAU,kBAAkB,CAAC,SAAc,EAAE,MAAW;IAC1D,IAAI,OAAO,CAAC,MAAM,CAAC,EAAE;QACjB,OAAO,MAAM,CAAC;KACjB;AACL,CAAC;AAED;;;GAGG;AACH,MAAM,UAAU,eAAe,CAAC,QAAkB,EAAE,IAAY;IAC5D,MAAM,KAAK,GAAG,QAAQ,CAAC,aAAa,CAAC,UAAU,CAAC,CAAC;IACjD,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;IAC5B,KAAK,CAAC,KAAK,GAAG,IAAI,CAAC;IACnB,KAAK,CAAC,MAAM,EAAE,CAAC;IACf,QAAQ,CAAC,WAAW,CAAC,MAAM,CAAC,CAAC;IAC7B,QAAQ,CAAC,IAAI,CAAC,WAAW,CAAC,KAAK,CAAC,CAAC;AACrC,CAAC;AAED,MAAM,UAAU,UAAU,CAAI,CAAI;IAC9B,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,CAAC,IAAI,UAAU,CAAC,CAAC,CAAC,CAAC,CAAC;IAEnE,OAAO,MAAM,CAAC,MAAM,CAAC,CAAC,CAAoB,CAAC;AAC/C,CAAC","sourcesContent":["import {isArray, isEmpty, isObject, pickBy} from 'lodash-es';\nimport {Literal} from '../types/types';\nimport type {ReadonlyDeep} from 'type-fest';\n\n/**\n * Very basic formatting to get only date, without time and ignoring entirely the timezone\n *\n * So something like: \"2021-09-23\"\n */\nexport function formatIsoDate(date: null): null;\nexport function formatIsoDate(date: Date): string;\nexport function formatIsoDate(date: Date | null): string | null;\nexport function formatIsoDate(date: Date | null): string | null {\n    if (!date) {\n        return null;\n    }\n\n    const y = date.getFullYear();\n    const m = date.getMonth() + 1;\n    const d = date.getDate();\n\n    return y + '-' + (m < 10 ? '0' : '') + m + '-' + (d < 10 ? '0' : '') + d;\n}\n\n/**\n * Format a date and time in a way that will preserve the local time zone.\n * This allow the server side to know the day (without time) that was selected on client side.\n *\n * So something like: \"2021-09-23T17:57:16+09:00\"\n */\nexport function formatIsoDateTime(date: Date): string {\n    const timezoneOffsetInMinutes = date.getTimezoneOffset();\n    const timezoneOffsetInHours = -Math.trunc(timezoneOffsetInMinutes / 60); // UTC minus local time\n    const sign = timezoneOffsetInHours >= 0 ? '+' : '-';\n    const hoursLeadingZero = Math.abs(timezoneOffsetInHours) < 10 ? '0' : '';\n    const remainderMinutes = -(timezoneOffsetInMinutes % 60);\n    const minutesLeadingZero = Math.abs(remainderMinutes) < 10 ? '0' : '';\n\n    // It's a bit unfortunate that we need to construct a new Date instance,\n    // but we don't want the original Date instance to be modified\n    const correctedDate = new Date(\n        date.getFullYear(),\n        date.getMonth(),\n        date.getDate(),\n        date.getHours(),\n        date.getMinutes(),\n        date.getSeconds(),\n        date.getMilliseconds(),\n    );\n    correctedDate.setHours(date.getHours() + timezoneOffsetInHours);\n\n    const iso = correctedDate\n        .toISOString()\n        .replace(/\\.\\d{3}Z/, '')\n        .replace('Z', '');\n\n    return (\n        iso +\n        sign +\n        hoursLeadingZero +\n        Math.abs(timezoneOffsetInHours).toString() +\n        ':' +\n        minutesLeadingZero +\n        remainderMinutes\n    );\n}\n\n/**\n * Relations to full objects are converted to their IDs only.\n *\n * So {user: {id: 123}} becomes {user: 123}\n */\nexport function relationsToIds(object: Literal): Literal {\n    const newObj: Literal = {};\n    Object.keys(object).forEach(key => {\n        let value: string | Literal = object[key];\n        if (isObject(value) && value.id) {\n            value = value.id;\n        } else if (isArray(value)) {\n            value = value.map((i: string | Literal) => (isObject(i) && i.id ? i.id : i));\n        } else if (isObject(value) && !(value instanceof File) && !(value instanceof Date)) {\n            value = pickBy(value, (v, k) => k !== '__typename'); // omit(value, ['__typename']) ?\n        }\n\n        newObj[key] = value;\n    });\n\n    return newObj;\n}\n\n/**\n * Remove from source object the attributes with same value as modified\n * Does not consider arrays\n */\nexport function cleanSameValues(source: Literal, modified: Literal): Literal {\n    Object.keys(source).forEach(key => {\n        if (source[key] instanceof Object) {\n            cleanSameValues(source[key], modified[key]);\n            if (isEmpty(source[key])) {\n                delete source[key];\n            }\n        } else if (modified && source[key] === modified[key]) {\n            delete source[key];\n        }\n    });\n\n    return source;\n}\n\n/**\n * Returns the plural form of the given name\n */\nexport function makePlural(name: string): string {\n    const plural = name + 's';\n\n    return plural.replace(/ys$/, 'ies').replace(/ss$/, 'ses').replace(/xs$/, 'xes');\n}\n\n/**\n * Returns the string with the first letter as capital\n */\nexport function upperCaseFirstLetter(term: string): string {\n    return term.charAt(0).toUpperCase() + term.slice(1);\n}\n\n/**\n * Returns the string with the first letter as lower case\n */\nexport function lowerCaseFirstLetter(term: string): string {\n    return term.charAt(0).toLowerCase() + term.slice(1);\n}\n\n/**\n * Replace all attributes of first object with the ones provided by the second, but keeps the reference\n */\nexport function replaceObjectKeepingReference(obj: Literal | null, newObj: Literal | null): void {\n    if (!obj || !newObj) {\n        return;\n    }\n\n    Object.keys(obj).forEach(key => {\n        delete obj[key];\n    });\n\n    Object.keys(newObj).forEach(key => {\n        obj[key] = newObj[key];\n    });\n}\n\n/**\n * Get contrasted color for text in the slider thumb\n * @param hexBgColor string in hexadecimals representing the background color\n */\nexport function getForegroundColor(hexBgColor: string): 'black' | 'white' {\n    const rgb = hexToRgb(hexBgColor.slice(0, 7)); // splice remove alpha and consider only \"visible\" color at 100% alpha\n    const o = Math.round((rgb.r * 299 + rgb.g * 587 + rgb.b * 114) / 1000);\n\n    return o > 125 ? 'black' : 'white';\n}\n\nfunction hexToRgb(hex: string): {r: number; g: number; b: number} {\n    // Expand shorthand form (e.g. \"03F\") to full form (e.g. \"0033FF\")\n    const shorthandRegex = /^#?([a-f\\d])([a-f\\d])([a-f\\d])$/i;\n    hex = hex.replace(shorthandRegex, (m, r, g, b) => {\n        return r + r + g + g + b + b;\n    });\n\n    const result = /^#?([a-f\\d]{2})([a-f\\d]{2})([a-f\\d]{2})$/i.exec(hex);\n    return result\n        ? {\n              r: parseInt(result[1], 16),\n              g: parseInt(result[2], 16),\n              b: parseInt(result[3], 16),\n          }\n        : {\n              r: 0,\n              g: 0,\n              b: 0,\n          };\n}\n\n/**\n * During lodash.mergeWith, overrides arrays\n */\nexport function mergeOverrideArray(destValue: any, source: any): any {\n    if (isArray(source)) {\n        return source;\n    }\n}\n\n/**\n * Copy text to clipboard.\n * Accepts line breaks `\\n` as textarea do.\n */\nexport function copyToClipboard(document: Document, text: string): void {\n    const input = document.createElement('textarea');\n    document.body.append(input);\n    input.value = text;\n    input.select();\n    document.execCommand('copy');\n    document.body.removeChild(input);\n}\n\nexport function deepFreeze<T>(o: T): ReadonlyDeep<T> {\n    Object.values(o).forEach(v => Object.isFrozen(v) || deepFreeze(v));\n\n    return Object.freeze(o) as ReadonlyDeep<T>;\n}\n"]}
|
|
@@ -130,4 +130,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.1.1", ngImpor
|
|
|
130
130
|
type: Inject,
|
|
131
131
|
args: [MAT_DATE_FORMATS]
|
|
132
132
|
}] }]; } });
|
|
133
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"type-date.component.js","sourceRoot":"","sources":["../../../../../../../projects/natural/src/lib/modules/dropdown-components/type-date/type-date.component.ts","../../../../../../../projects/natural/src/lib/modules/dropdown-components/type-date/type-date.component.html"],"names":[],"mappings":"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","sourcesContent":["import {Component, Inject} from '@angular/core';\nimport {FormControl, FormGroup, ValidatorFn, Validators} from '@angular/forms';\nimport {DateAdapter, MAT_DATE_FORMATS, MatDateFormats} from '@angular/material/core';\nimport {BehaviorSubject, merge} from 'rxjs';\nimport {FilterGroupConditionField} from '../../search/classes/graphql-doctrine.types';\nimport {NATURAL_DROPDOWN_DATA, NaturalDropdownData} from '../../search/dropdown-container/dropdown.service';\nimport {DropdownComponent} from '../../search/types/dropdown-component';\nimport {possibleComparableOperators, PossibleComparableOpertorKeys} from '../types';\nimport {dateMax, dateMin, serialize} from '../utils';\n\nexport interface TypeDateConfiguration<D = any> {\n    min?: D | null;\n    max?: D | null;\n}\n\n@Component({\n    templateUrl: './type-date.component.html',\n})\nexport class TypeDateComponent<D = any> implements DropdownComponent {\n    public readonly renderedValue = new BehaviorSubject<string>('');\n    public readonly configuration: TypeDateConfiguration<D>;\n    public readonly operatorCtrl = new FormControl<PossibleComparableOpertorKeys>('equal', {nonNullable: true});\n    public readonly valueCtrl = new FormControl<D | null>(null);\n    public readonly operators = possibleComparableOperators;\n\n    public readonly form = new FormGroup({\n        operator: this.operatorCtrl,\n        value: this.valueCtrl,\n    });\n\n    private readonly defaults: TypeDateConfiguration<D> = {\n        min: null,\n        max: null,\n    };\n\n    public constructor(\n        @Inject(NATURAL_DROPDOWN_DATA) data: NaturalDropdownData<TypeDateConfiguration<D>>,\n        private dateAdapter: DateAdapter<D>,\n        @Inject(MAT_DATE_FORMATS) private dateFormats: MatDateFormats,\n    ) {\n        this.configuration = {...this.defaults, ...data.configuration};\n\n        merge(this.operatorCtrl.valueChanges, this.valueCtrl.valueChanges).subscribe(() => {\n            this.renderedValue.next(this.getRenderedValue());\n        });\n\n        this.initValidators();\n        this.reloadCondition(data.condition);\n    }\n\n    public getCondition(): FilterGroupConditionField {\n        if (!this.valueCtrl.value) {\n            return {};\n        }\n\n        const condition: FilterGroupConditionField = {};\n        let operator = this.operatorCtrl.value;\n        let date = this.valueCtrl.value;\n        const dayAfter = this.getDayAfter(date);\n        if (operator === 'equal') {\n            condition.greaterOrEqual = {\n                value: serialize<D>(this.dateAdapter, date),\n            };\n            condition.less = {\n                value: serialize<D>(this.dateAdapter, dayAfter),\n            };\n        } else {\n            // Transparently adapt exclusive/inclusive ranges\n            if (operator === 'greater') {\n                operator = 'greaterOrEqual';\n                date = dayAfter;\n            } else if (operator === 'lessOrEqual') {\n                operator = 'less';\n                date = dayAfter;\n            }\n\n            condition[operator] = {\n                value: serialize<D>(this.dateAdapter, date),\n            };\n        }\n\n        return condition;\n    }\n\n    public isValid(): boolean {\n        return this.form.valid;\n    }\n\n    public isDirty(): boolean {\n        return this.form.dirty;\n    }\n\n    private reloadCondition(condition: FilterGroupConditionField | null): void {\n        if (!condition) {\n            return;\n        }\n\n        // Special case for '='\n        if (condition.greaterOrEqual && condition.less) {\n            this.operatorCtrl.setValue('equal');\n            const value = this.dateAdapter.deserialize(condition.greaterOrEqual.value);\n            this.valueCtrl.setValue(value);\n\n            return;\n        }\n\n        for (const operator of this.operators) {\n            const reloadedOperator = condition[operator.key];\n            if (reloadedOperator) {\n                this.operatorCtrl.setValue(operator.key);\n\n                const value = this.dateAdapter.deserialize(reloadedOperator.value);\n                this.valueCtrl.setValue(value);\n            }\n        }\n    }\n\n    private initValidators(): void {\n        const validators: ValidatorFn[] = [Validators.required];\n        if (this.configuration.min) {\n            validators.push(dateMin<D>(this.dateAdapter, this.configuration.min));\n        }\n\n        if (this.configuration.max) {\n            validators.push(dateMax<D>(this.dateAdapter, this.configuration.max));\n        }\n\n        this.valueCtrl.setValidators(validators);\n    }\n\n    private getDayAfter(date: D): D {\n        return this.dateAdapter.addCalendarDays(this.dateAdapter.clone(date), 1);\n    }\n\n    private getRenderedValue(): string {\n        const operator = this.operators.find(v => v.key === this.operatorCtrl.value);\n        if (this.valueCtrl.value === null || !operator) {\n            return '';\n        } else {\n            const value = this.dateAdapter.format(this.valueCtrl.value, this.dateFormats.display.dateInput);\n\n            return operator.label + ' ' + value;\n        }\n    }\n}\n","<form [formGroup]=\"form\">\n    <mat-form-field style=\"max-width: 4em; margin-right: 1em\">\n        <mat-label i18n=\"Mathematical operator < > =\">Opérateur</mat-label>\n        <mat-select [formControl]=\"operatorCtrl\" [required]=\"true\">\n            <mat-option *ngFor=\"let item of operators\" [value]=\"item.key\">\n                {{ item.label }}\n            </mat-option>\n        </mat-select>\n    </mat-form-field>\n\n    <mat-form-field>\n        <mat-label i18n>Date</mat-label>\n        <input\n            [formControl]=\"valueCtrl\"\n            [matDatepicker]=\"value\"\n            [max]=\"configuration.max\"\n            [min]=\"configuration.min\"\n            [required]=\"true\"\n            matInput\n        />\n        <mat-datepicker-toggle [for]=\"value\" matSuffix></mat-datepicker-toggle>\n        <mat-datepicker #value></mat-datepicker>\n        <mat-error>\n            <span *ngIf=\"valueCtrl.hasError('min')\">< {{ configuration.min }}</span>\n            <span *ngIf=\"valueCtrl.hasError('max')\">> {{ configuration.max }}</span>\n            <span *ngIf=\"valueCtrl.hasError('required')\">*</span>\n        </mat-error>\n    </mat-form-field>\n</form>\n"]}
|
|
133
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"type-date.component.js","sourceRoot":"","sources":["../../../../../../../projects/natural/src/lib/modules/dropdown-components/type-date/type-date.component.ts","../../../../../../../projects/natural/src/lib/modules/dropdown-components/type-date/type-date.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAC,SAAS,EAAE,MAAM,EAAC,MAAM,eAAe,CAAC;AAChD,OAAO,EAAC,WAAW,EAAE,SAAS,EAAe,UAAU,EAAC,MAAM,gBAAgB,CAAC;AAC/E,OAAO,EAAc,gBAAgB,EAAiB,MAAM,wBAAwB,CAAC;AACrF,OAAO,EAAC,eAAe,EAAE,KAAK,EAAC,MAAM,MAAM,CAAC;AAE5C,OAAO,EAAC,qBAAqB,EAAsB,MAAM,kDAAkD,CAAC;AAE5G,OAAO,EAAC,2BAA2B,EAAgC,MAAM,UAAU,CAAC;AACpF,OAAO,EAAC,OAAO,EAAE,OAAO,EAAE,SAAS,EAAC,MAAM,UAAU,CAAC;;;;;;;;;AAUrD,MAAM,OAAO,iBAAiB;IAiB1B,YACmC,IAAmD,EAC1E,WAA2B,EACD,WAA2B;QADrD,gBAAW,GAAX,WAAW,CAAgB;QACD,gBAAW,GAAX,WAAW,CAAgB;QAnBjD,kBAAa,GAAG,IAAI,eAAe,CAAS,EAAE,CAAC,CAAC;QAEhD,iBAAY,GAAG,IAAI,WAAW,CAAgC,OAAO,EAAE,EAAC,WAAW,EAAE,IAAI,EAAC,CAAC,CAAC;QAC5F,cAAS,GAAG,IAAI,WAAW,CAAW,IAAI,CAAC,CAAC;QAC5C,cAAS,GAAG,2BAA2B,CAAC;QAExC,SAAI,GAAG,IAAI,SAAS,CAAC;YACjC,QAAQ,EAAE,IAAI,CAAC,YAAY;YAC3B,KAAK,EAAE,IAAI,CAAC,SAAS;SACxB,CAAC,CAAC;QAEc,aAAQ,GAAuC;YAC5D,GAAG,EAAE,IAAI;YACT,GAAG,EAAE,IAAI;SACZ,CAAC;QAOE,IAAI,CAAC,aAAa,GAAG,EAAC,GAAG,IAAI,CAAC,QAAQ,EAAE,GAAG,IAAI,CAAC,aAAa,EAAC,CAAC;QAE/D,KAAK,CAAC,IAAI,CAAC,YAAY,CAAC,YAAY,EAAE,IAAI,CAAC,SAAS,CAAC,YAAY,CAAC,CAAC,SAAS,CAAC,GAAG,EAAE;YAC9E,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,IAAI,CAAC,gBAAgB,EAAE,CAAC,CAAC;QACrD,CAAC,CAAC,CAAC;QAEH,IAAI,CAAC,cAAc,EAAE,CAAC;QACtB,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;IACzC,CAAC;IAEM,YAAY;QACf,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,KAAK,EAAE;YACvB,OAAO,EAAE,CAAC;SACb;QAED,MAAM,SAAS,GAA8B,EAAE,CAAC;QAChD,IAAI,QAAQ,GAAG,IAAI,CAAC,YAAY,CAAC,KAAK,CAAC;QACvC,IAAI,IAAI,GAAG,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC;QAChC,MAAM,QAAQ,GAAG,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC;QACxC,IAAI,QAAQ,KAAK,OAAO,EAAE;YACtB,SAAS,CAAC,cAAc,GAAG;gBACvB,KAAK,EAAE,SAAS,CAAI,IAAI,CAAC,WAAW,EAAE,IAAI,CAAC;aAC9C,CAAC;YACF,SAAS,CAAC,IAAI,GAAG;gBACb,KAAK,EAAE,SAAS,CAAI,IAAI,CAAC,WAAW,EAAE,QAAQ,CAAC;aAClD,CAAC;SACL;aAAM;YACH,iDAAiD;YACjD,IAAI,QAAQ,KAAK,SAAS,EAAE;gBACxB,QAAQ,GAAG,gBAAgB,CAAC;gBAC5B,IAAI,GAAG,QAAQ,CAAC;aACnB;iBAAM,IAAI,QAAQ,KAAK,aAAa,EAAE;gBACnC,QAAQ,GAAG,MAAM,CAAC;gBAClB,IAAI,GAAG,QAAQ,CAAC;aACnB;YAED,SAAS,CAAC,QAAQ,CAAC,GAAG;gBAClB,KAAK,EAAE,SAAS,CAAI,IAAI,CAAC,WAAW,EAAE,IAAI,CAAC;aAC9C,CAAC;SACL;QAED,OAAO,SAAS,CAAC;IACrB,CAAC;IAEM,OAAO;QACV,OAAO,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC;IAC3B,CAAC;IAEM,OAAO;QACV,OAAO,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC;IAC3B,CAAC;IAEO,eAAe,CAAC,SAA2C;QAC/D,IAAI,CAAC,SAAS,EAAE;YACZ,OAAO;SACV;QAED,uBAAuB;QACvB,IAAI,SAAS,CAAC,cAAc,IAAI,SAAS,CAAC,IAAI,EAAE;YAC5C,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC;YACpC,MAAM,KAAK,GAAG,IAAI,CAAC,WAAW,CAAC,WAAW,CAAC,SAAS,CAAC,cAAc,CAAC,KAAK,CAAC,CAAC;YAC3E,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;YAE/B,OAAO;SACV;QAED,KAAK,MAAM,QAAQ,IAAI,IAAI,CAAC,SAAS,EAAE;YACnC,MAAM,gBAAgB,GAAG,SAAS,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC;YACjD,IAAI,gBAAgB,EAAE;gBAClB,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC;gBAEzC,MAAM,KAAK,GAAG,IAAI,CAAC,WAAW,CAAC,WAAW,CAAC,gBAAgB,CAAC,KAAK,CAAC,CAAC;gBACnE,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;aAClC;SACJ;IACL,CAAC;IAEO,cAAc;QAClB,MAAM,UAAU,GAAkB,CAAC,UAAU,CAAC,QAAQ,CAAC,CAAC;QACxD,IAAI,IAAI,CAAC,aAAa,CAAC,GAAG,EAAE;YACxB,UAAU,CAAC,IAAI,CAAC,OAAO,CAAI,IAAI,CAAC,WAAW,EAAE,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,CAAC,CAAC;SACzE;QAED,IAAI,IAAI,CAAC,aAAa,CAAC,GAAG,EAAE;YACxB,UAAU,CAAC,IAAI,CAAC,OAAO,CAAI,IAAI,CAAC,WAAW,EAAE,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,CAAC,CAAC;SACzE;QAED,IAAI,CAAC,SAAS,CAAC,aAAa,CAAC,UAAU,CAAC,CAAC;IAC7C,CAAC;IAEO,WAAW,CAAC,IAAO;QACvB,OAAO,IAAI,CAAC,WAAW,CAAC,eAAe,CAAC,IAAI,CAAC,WAAW,CAAC,KAAK,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,CAAC;IAC7E,CAAC;IAEO,gBAAgB;QACpB,MAAM,QAAQ,GAAG,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,GAAG,KAAK,IAAI,CAAC,YAAY,CAAC,KAAK,CAAC,CAAC;QAC7E,IAAI,IAAI,CAAC,SAAS,CAAC,KAAK,KAAK,IAAI,IAAI,CAAC,QAAQ,EAAE;YAC5C,OAAO,EAAE,CAAC;SACb;aAAM;YACH,MAAM,KAAK,GAAG,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,KAAK,EAAE,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC;YAEhG,OAAO,QAAQ,CAAC,KAAK,GAAG,GAAG,GAAG,KAAK,CAAC;SACvC;IACL,CAAC;;8GA7HQ,iBAAiB,kBAkBd,qBAAqB,wCAErB,gBAAgB;kGApBnB,iBAAiB,oDClB9B,qrCA6BA;2FDXa,iBAAiB;kBAH7B,SAAS;;;0BAqBD,MAAM;2BAAC,qBAAqB;;0BAE5B,MAAM;2BAAC,gBAAgB","sourcesContent":["import {Component, Inject} from '@angular/core';\nimport {FormControl, FormGroup, ValidatorFn, Validators} from '@angular/forms';\nimport {DateAdapter, MAT_DATE_FORMATS, MatDateFormats} from '@angular/material/core';\nimport {BehaviorSubject, merge} from 'rxjs';\nimport {FilterGroupConditionField} from '../../search/classes/graphql-doctrine.types';\nimport {NATURAL_DROPDOWN_DATA, NaturalDropdownData} from '../../search/dropdown-container/dropdown.service';\nimport {DropdownComponent} from '../../search/types/dropdown-component';\nimport {possibleComparableOperators, PossibleComparableOpertorKeys} from '../types';\nimport {dateMax, dateMin, serialize} from '../utils';\n\nexport interface TypeDateConfiguration<D = any> {\n    min?: D | null;\n    max?: D | null;\n}\n\n@Component({\n    templateUrl: './type-date.component.html',\n})\nexport class TypeDateComponent<D = any> implements DropdownComponent {\n    public readonly renderedValue = new BehaviorSubject<string>('');\n    public readonly configuration: Required<TypeDateConfiguration<D>>;\n    public readonly operatorCtrl = new FormControl<PossibleComparableOpertorKeys>('equal', {nonNullable: true});\n    public readonly valueCtrl = new FormControl<D | null>(null);\n    public readonly operators = possibleComparableOperators;\n\n    public readonly form = new FormGroup({\n        operator: this.operatorCtrl,\n        value: this.valueCtrl,\n    });\n\n    private readonly defaults: Required<TypeDateConfiguration<D>> = {\n        min: null,\n        max: null,\n    };\n\n    public constructor(\n        @Inject(NATURAL_DROPDOWN_DATA) data: NaturalDropdownData<TypeDateConfiguration<D>>,\n        private dateAdapter: DateAdapter<D>,\n        @Inject(MAT_DATE_FORMATS) private dateFormats: MatDateFormats,\n    ) {\n        this.configuration = {...this.defaults, ...data.configuration};\n\n        merge(this.operatorCtrl.valueChanges, this.valueCtrl.valueChanges).subscribe(() => {\n            this.renderedValue.next(this.getRenderedValue());\n        });\n\n        this.initValidators();\n        this.reloadCondition(data.condition);\n    }\n\n    public getCondition(): FilterGroupConditionField {\n        if (!this.valueCtrl.value) {\n            return {};\n        }\n\n        const condition: FilterGroupConditionField = {};\n        let operator = this.operatorCtrl.value;\n        let date = this.valueCtrl.value;\n        const dayAfter = this.getDayAfter(date);\n        if (operator === 'equal') {\n            condition.greaterOrEqual = {\n                value: serialize<D>(this.dateAdapter, date),\n            };\n            condition.less = {\n                value: serialize<D>(this.dateAdapter, dayAfter),\n            };\n        } else {\n            // Transparently adapt exclusive/inclusive ranges\n            if (operator === 'greater') {\n                operator = 'greaterOrEqual';\n                date = dayAfter;\n            } else if (operator === 'lessOrEqual') {\n                operator = 'less';\n                date = dayAfter;\n            }\n\n            condition[operator] = {\n                value: serialize<D>(this.dateAdapter, date),\n            };\n        }\n\n        return condition;\n    }\n\n    public isValid(): boolean {\n        return this.form.valid;\n    }\n\n    public isDirty(): boolean {\n        return this.form.dirty;\n    }\n\n    private reloadCondition(condition: FilterGroupConditionField | null): void {\n        if (!condition) {\n            return;\n        }\n\n        // Special case for '='\n        if (condition.greaterOrEqual && condition.less) {\n            this.operatorCtrl.setValue('equal');\n            const value = this.dateAdapter.deserialize(condition.greaterOrEqual.value);\n            this.valueCtrl.setValue(value);\n\n            return;\n        }\n\n        for (const operator of this.operators) {\n            const reloadedOperator = condition[operator.key];\n            if (reloadedOperator) {\n                this.operatorCtrl.setValue(operator.key);\n\n                const value = this.dateAdapter.deserialize(reloadedOperator.value);\n                this.valueCtrl.setValue(value);\n            }\n        }\n    }\n\n    private initValidators(): void {\n        const validators: ValidatorFn[] = [Validators.required];\n        if (this.configuration.min) {\n            validators.push(dateMin<D>(this.dateAdapter, this.configuration.min));\n        }\n\n        if (this.configuration.max) {\n            validators.push(dateMax<D>(this.dateAdapter, this.configuration.max));\n        }\n\n        this.valueCtrl.setValidators(validators);\n    }\n\n    private getDayAfter(date: D): D {\n        return this.dateAdapter.addCalendarDays(this.dateAdapter.clone(date), 1);\n    }\n\n    private getRenderedValue(): string {\n        const operator = this.operators.find(v => v.key === this.operatorCtrl.value);\n        if (this.valueCtrl.value === null || !operator) {\n            return '';\n        } else {\n            const value = this.dateAdapter.format(this.valueCtrl.value, this.dateFormats.display.dateInput);\n\n            return operator.label + ' ' + value;\n        }\n    }\n}\n","<form [formGroup]=\"form\">\n    <mat-form-field style=\"max-width: 4em; margin-right: 1em\">\n        <mat-label i18n=\"Mathematical operator < > =\">Opérateur</mat-label>\n        <mat-select [formControl]=\"operatorCtrl\" [required]=\"true\">\n            <mat-option *ngFor=\"let item of operators\" [value]=\"item.key\">\n                {{ item.label }}\n            </mat-option>\n        </mat-select>\n    </mat-form-field>\n\n    <mat-form-field>\n        <mat-label i18n>Date</mat-label>\n        <input\n            [formControl]=\"valueCtrl\"\n            [matDatepicker]=\"value\"\n            [max]=\"configuration.max\"\n            [min]=\"configuration.min\"\n            [required]=\"true\"\n            matInput\n        />\n        <mat-datepicker-toggle [for]=\"value\" matSuffix></mat-datepicker-toggle>\n        <mat-datepicker #value></mat-datepicker>\n        <mat-error>\n            <span *ngIf=\"valueCtrl.hasError('min')\">< {{ configuration.min }}</span>\n            <span *ngIf=\"valueCtrl.hasError('max')\">> {{ configuration.max }}</span>\n            <span *ngIf=\"valueCtrl.hasError('required')\">*</span>\n        </mat-error>\n    </mat-form-field>\n</form>\n"]}
|
package/esm2020/lib/modules/dropdown-components/type-date-range/type-date-range.component.mjs
CHANGED
|
@@ -134,4 +134,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.1.1", ngImpor
|
|
|
134
134
|
type: Inject,
|
|
135
135
|
args: [MAT_DATE_FORMATS]
|
|
136
136
|
}] }]; } });
|
|
137
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"type-date-range.component.js","sourceRoot":"","sources":["../../../../../../../projects/natural/src/lib/modules/dropdown-components/type-date-range/type-date-range.component.ts","../../../../../../../projects/natural/src/lib/modules/dropdown-components/type-date-range/type-date-range.component.html"],"names":[],"mappings":"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","sourcesContent":["import {Component, Inject} from '@angular/core';\nimport {\n    AbstractControl,\n    FormControl,\n    FormGroup,\n    FormGroupDirective,\n    NgForm,\n    ValidationErrors,\n    ValidatorFn,\n    Validators,\n} from '@angular/forms';\nimport {DateAdapter, ErrorStateMatcher, MAT_DATE_FORMATS, MatDateFormats} from '@angular/material/core';\nimport {BehaviorSubject, merge} from 'rxjs';\nimport {DropdownComponent} from '../../search/types/dropdown-component';\nimport {NATURAL_DROPDOWN_DATA, NaturalDropdownData} from '../../search/dropdown-container/dropdown.service';\nimport {FilterGroupConditionField} from '../../search/classes/graphql-doctrine.types';\nimport {dateMax, dateMin, serialize} from '../utils';\n\nexport interface TypeDateRangeConfiguration<D = any> {\n    min?: D | null;\n    max?: D | null;\n}\n\nclass InvalidWithValueStateMatcher implements ErrorStateMatcher {\n    public isErrorState(control: FormControl<unknown> | null, form: FormGroupDirective | NgForm | null): boolean {\n        return (form && form.invalid && (form.value.to || form.value.from)) || (control && control.invalid);\n    }\n}\n\nfunction parseFromControl<D>(control: AbstractControl, key: string): D | null {\n    const c = control.get(key);\n    if (!c) {\n        return null;\n    }\n\n    return c.value;\n}\n\n/**\n * From >= To\n */\nfunction toGreaterThanFrom<D>(dateAdapter: DateAdapter<D>): ValidatorFn {\n    return (control: AbstractControl): ValidationErrors | null => {\n        const from = parseFromControl<D>(control, 'from');\n        const to = parseFromControl<D>(control, 'to');\n\n        if (from && to && dateAdapter.compareDate(from, to) > 0) {\n            return {toGreaterThanFrom: true};\n        }\n\n        return null;\n    };\n}\n\n/**\n * Date range with mandatory bounding dates.\n *\n * If you need ooptional bounding date, then use `TypeDateComponent` instead.\n */\n@Component({\n    templateUrl: './type-date-range.component.html',\n})\nexport class TypeDateRangeComponent<D = any> implements DropdownComponent {\n    public readonly renderedValue = new BehaviorSubject<string>('');\n    public readonly configuration: TypeDateRangeConfiguration<D>;\n    public readonly matcher = new InvalidWithValueStateMatcher();\n    public readonly fromCtrl = new FormControl<D | null>(null);\n    public readonly toCtrl = new FormControl<D | null>(null);\n    public readonly form = new FormGroup({\n        from: this.fromCtrl,\n        to: this.toCtrl,\n    });\n\n    private readonly defaults: TypeDateRangeConfiguration<D> = {\n        min: null,\n        max: null,\n    };\n\n    public constructor(\n        @Inject(NATURAL_DROPDOWN_DATA) data: NaturalDropdownData<TypeDateRangeConfiguration<D>>,\n        private dateAdapter: DateAdapter<D>,\n        @Inject(MAT_DATE_FORMATS) private dateFormats: MatDateFormats,\n    ) {\n        this.configuration = {...this.defaults, ...data.configuration};\n\n        merge(this.fromCtrl.valueChanges, this.toCtrl.valueChanges).subscribe(() => {\n            this.renderedValue.next(this.getRenderedValue());\n        });\n\n        this.initValidators();\n        this.reloadCondition(data.condition);\n    }\n\n    public getCondition(): FilterGroupConditionField {\n        const from = serialize<D>(this.dateAdapter, this.fromCtrl.value);\n        const to = serialize<D>(this.dateAdapter, this.toCtrl.value);\n\n        if (from && to) {\n            return {between: {from, to}};\n        } else {\n            return {};\n        }\n    }\n\n    public isValid(): boolean {\n        return this.form.valid;\n    }\n\n    public isDirty(): boolean {\n        return this.form.dirty;\n    }\n\n    private reloadCondition(condition: FilterGroupConditionField | null): void {\n        if (!condition) {\n            return;\n        }\n\n        const value = {\n            from: null as D | null,\n            to: null as D | null,\n        };\n\n        if (condition.between) {\n            value.from = this.dateAdapter.parse(condition.between.from, null);\n            value.to = this.dateAdapter.parse(condition.between.to, null);\n        }\n\n        this.form.setValue(value);\n    }\n\n    private initValidators(): void {\n        const validators: ValidatorFn[] = [Validators.required];\n        if (this.configuration.min) {\n            validators.push(dateMin<D>(this.dateAdapter, this.configuration.min));\n        }\n\n        if (this.configuration.max) {\n            validators.push(dateMax<D>(this.dateAdapter, this.configuration.max));\n        }\n\n        this.fromCtrl.setValidators(validators);\n        this.toCtrl.setValidators(validators);\n\n        this.form.setValidators([\n            toGreaterThanFrom<D>(this.dateAdapter), // From < To\n        ]);\n    }\n\n    public render(value: D | null): string {\n        return value ? this.dateAdapter.format(value, this.dateFormats.display.dateInput) : '';\n    }\n\n    private getRenderedValue(): string {\n        const from = this.render(this.fromCtrl.value);\n        const to = this.render(this.toCtrl.value);\n\n        if (from && to) {\n            return from + ' - ' + to;\n        } else {\n            return '';\n        }\n    }\n}\n","<form [formGroup]=\"form\">\n    <mat-form-field>\n        <input\n            matInput\n            [matDatepicker]=\"from\"\n            placeholder=\"De\"\n            [formControl]=\"fromCtrl\"\n            [errorStateMatcher]=\"matcher\"\n            [min]=\"configuration.min\"\n            [max]=\"configuration.max\"\n        />\n        <mat-datepicker-toggle matSuffix [for]=\"from\"></mat-datepicker-toggle>\n        <mat-datepicker #from></mat-datepicker>\n        <mat-error>\n            <span *ngIf=\"form.hasError('toGreaterThanFrom')\"\n                >{{ render(fromCtrl.value) }} > {{ render(toCtrl.value) }}</span\n            >\n            <span *ngIf=\"fromCtrl.hasError('min') && !form.hasError('toGreaterThanFrom')\"\n                >< {{ configuration.min }}</span\n            >\n            <span *ngIf=\"fromCtrl.hasError('max') && !form.hasError('toGreaterThanFrom')\"\n                >> {{ configuration.max }}</span\n            >\n            <span *ngIf=\"fromCtrl.hasError('required')\">*</span>\n        </mat-error>\n    </mat-form-field>\n\n    <mat-form-field>\n        <input\n            matInput\n            [matDatepicker]=\"to\"\n            placeholder=\"à\"\n            [formControl]=\"toCtrl\"\n            [errorStateMatcher]=\"matcher\"\n            [min]=\"configuration.min\"\n            [max]=\"configuration.max\"\n        />\n        <mat-datepicker-toggle matSuffix [for]=\"to\"></mat-datepicker-toggle>\n        <mat-datepicker #to></mat-datepicker>\n        <mat-error>\n            <span *ngIf=\"toCtrl.hasError('min') && !form.hasError('toGreaterThanFrom')\">< {{ configuration.min }}</span>\n            <span *ngIf=\"toCtrl.hasError('max') && !form.hasError('toGreaterThanFrom')\">> {{ configuration.max }}</span>\n            <span *ngIf=\"toCtrl.hasError('required')\">*</span>\n        </mat-error>\n    </mat-form-field>\n</form>\n"]}
|
|
137
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"type-date-range.component.js","sourceRoot":"","sources":["../../../../../../../projects/natural/src/lib/modules/dropdown-components/type-date-range/type-date-range.component.ts","../../../../../../../projects/natural/src/lib/modules/dropdown-components/type-date-range/type-date-range.component.html"],"names":[],"mappings":"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","sourcesContent":["import {Component, Inject} from '@angular/core';\nimport {\n    AbstractControl,\n    FormControl,\n    FormGroup,\n    FormGroupDirective,\n    NgForm,\n    ValidationErrors,\n    ValidatorFn,\n    Validators,\n} from '@angular/forms';\nimport {DateAdapter, ErrorStateMatcher, MAT_DATE_FORMATS, MatDateFormats} from '@angular/material/core';\nimport {BehaviorSubject, merge} from 'rxjs';\nimport {DropdownComponent} from '../../search/types/dropdown-component';\nimport {NATURAL_DROPDOWN_DATA, NaturalDropdownData} from '../../search/dropdown-container/dropdown.service';\nimport {FilterGroupConditionField} from '../../search/classes/graphql-doctrine.types';\nimport {dateMax, dateMin, serialize} from '../utils';\n\nexport interface TypeDateRangeConfiguration<D = any> {\n    min?: D | null;\n    max?: D | null;\n}\n\nclass InvalidWithValueStateMatcher implements ErrorStateMatcher {\n    public isErrorState(control: FormControl<unknown> | null, form: FormGroupDirective | NgForm | null): boolean {\n        return (form && form.invalid && (form.value.to || form.value.from)) || (control && control.invalid);\n    }\n}\n\nfunction parseFromControl<D>(control: AbstractControl, key: string): D | null {\n    const c = control.get(key);\n    if (!c) {\n        return null;\n    }\n\n    return c.value;\n}\n\n/**\n * From >= To\n */\nfunction toGreaterThanFrom<D>(dateAdapter: DateAdapter<D>): ValidatorFn {\n    return (control: AbstractControl): ValidationErrors | null => {\n        const from = parseFromControl<D>(control, 'from');\n        const to = parseFromControl<D>(control, 'to');\n\n        if (from && to && dateAdapter.compareDate(from, to) > 0) {\n            return {toGreaterThanFrom: true};\n        }\n\n        return null;\n    };\n}\n\n/**\n * Date range with mandatory bounding dates.\n *\n * If you need ooptional bounding date, then use `TypeDateComponent` instead.\n */\n@Component({\n    templateUrl: './type-date-range.component.html',\n})\nexport class TypeDateRangeComponent<D = any> implements DropdownComponent {\n    public readonly renderedValue = new BehaviorSubject<string>('');\n    public readonly configuration: Required<TypeDateRangeConfiguration<D>>;\n    public readonly matcher = new InvalidWithValueStateMatcher();\n    public readonly fromCtrl = new FormControl<D | null>(null);\n    public readonly toCtrl = new FormControl<D | null>(null);\n    public readonly form = new FormGroup({\n        from: this.fromCtrl,\n        to: this.toCtrl,\n    });\n\n    private readonly defaults: Required<TypeDateRangeConfiguration<D>> = {\n        min: null,\n        max: null,\n    };\n\n    public constructor(\n        @Inject(NATURAL_DROPDOWN_DATA) data: NaturalDropdownData<TypeDateRangeConfiguration<D>>,\n        private dateAdapter: DateAdapter<D>,\n        @Inject(MAT_DATE_FORMATS) private dateFormats: MatDateFormats,\n    ) {\n        this.configuration = {...this.defaults, ...data.configuration};\n\n        merge(this.fromCtrl.valueChanges, this.toCtrl.valueChanges).subscribe(() => {\n            this.renderedValue.next(this.getRenderedValue());\n        });\n\n        this.initValidators();\n        this.reloadCondition(data.condition);\n    }\n\n    public getCondition(): FilterGroupConditionField {\n        const from = serialize<D>(this.dateAdapter, this.fromCtrl.value);\n        const to = serialize<D>(this.dateAdapter, this.toCtrl.value);\n\n        if (from && to) {\n            return {between: {from, to}};\n        } else {\n            return {};\n        }\n    }\n\n    public isValid(): boolean {\n        return this.form.valid;\n    }\n\n    public isDirty(): boolean {\n        return this.form.dirty;\n    }\n\n    private reloadCondition(condition: FilterGroupConditionField | null): void {\n        if (!condition) {\n            return;\n        }\n\n        const value = {\n            from: null as D | null,\n            to: null as D | null,\n        };\n\n        if (condition.between) {\n            value.from = this.dateAdapter.parse(condition.between.from, null);\n            value.to = this.dateAdapter.parse(condition.between.to, null);\n        }\n\n        this.form.setValue(value);\n    }\n\n    private initValidators(): void {\n        const validators: ValidatorFn[] = [Validators.required];\n        if (this.configuration.min) {\n            validators.push(dateMin<D>(this.dateAdapter, this.configuration.min));\n        }\n\n        if (this.configuration.max) {\n            validators.push(dateMax<D>(this.dateAdapter, this.configuration.max));\n        }\n\n        this.fromCtrl.setValidators(validators);\n        this.toCtrl.setValidators(validators);\n\n        this.form.setValidators([\n            toGreaterThanFrom<D>(this.dateAdapter), // From < To\n        ]);\n    }\n\n    public render(value: D | null): string {\n        return value ? this.dateAdapter.format(value, this.dateFormats.display.dateInput) : '';\n    }\n\n    private getRenderedValue(): string {\n        const from = this.render(this.fromCtrl.value);\n        const to = this.render(this.toCtrl.value);\n\n        if (from && to) {\n            return from + ' - ' + to;\n        } else {\n            return '';\n        }\n    }\n}\n","<form [formGroup]=\"form\">\n    <mat-form-field>\n        <input\n            matInput\n            [matDatepicker]=\"from\"\n            placeholder=\"De\"\n            [formControl]=\"fromCtrl\"\n            [errorStateMatcher]=\"matcher\"\n            [min]=\"configuration.min\"\n            [max]=\"configuration.max\"\n        />\n        <mat-datepicker-toggle matSuffix [for]=\"from\"></mat-datepicker-toggle>\n        <mat-datepicker #from></mat-datepicker>\n        <mat-error>\n            <span *ngIf=\"form.hasError('toGreaterThanFrom')\"\n                >{{ render(fromCtrl.value) }} > {{ render(toCtrl.value) }}</span\n            >\n            <span *ngIf=\"fromCtrl.hasError('min') && !form.hasError('toGreaterThanFrom')\"\n                >< {{ configuration.min }}</span\n            >\n            <span *ngIf=\"fromCtrl.hasError('max') && !form.hasError('toGreaterThanFrom')\"\n                >> {{ configuration.max }}</span\n            >\n            <span *ngIf=\"fromCtrl.hasError('required')\">*</span>\n        </mat-error>\n    </mat-form-field>\n\n    <mat-form-field>\n        <input\n            matInput\n            [matDatepicker]=\"to\"\n            placeholder=\"à\"\n            [formControl]=\"toCtrl\"\n            [errorStateMatcher]=\"matcher\"\n            [min]=\"configuration.min\"\n            [max]=\"configuration.max\"\n        />\n        <mat-datepicker-toggle matSuffix [for]=\"to\"></mat-datepicker-toggle>\n        <mat-datepicker #to></mat-datepicker>\n        <mat-error>\n            <span *ngIf=\"toCtrl.hasError('min') && !form.hasError('toGreaterThanFrom')\">< {{ configuration.min }}</span>\n            <span *ngIf=\"toCtrl.hasError('max') && !form.hasError('toGreaterThanFrom')\">> {{ configuration.max }}</span>\n            <span *ngIf=\"toCtrl.hasError('required')\">*</span>\n        </mat-error>\n    </mat-form-field>\n</form>\n"]}
|
|
@@ -17,7 +17,6 @@ export class TypeNumberComponent {
|
|
|
17
17
|
constructor(data, dropdownRef) {
|
|
18
18
|
this.dropdownRef = dropdownRef;
|
|
19
19
|
this.renderedValue = new BehaviorSubject('');
|
|
20
|
-
this.configuration = {};
|
|
21
20
|
this.operatorCtrl = new FormControl('equal', { nonNullable: true });
|
|
22
21
|
this.valueCtrl = new FormControl();
|
|
23
22
|
this.matcher = new InvalidWithValueStateMatcher();
|
|
@@ -26,7 +25,12 @@ export class TypeNumberComponent {
|
|
|
26
25
|
value: this.valueCtrl,
|
|
27
26
|
});
|
|
28
27
|
this.operators = possibleComparableOperators;
|
|
29
|
-
this.
|
|
28
|
+
this.defaults = {
|
|
29
|
+
min: null,
|
|
30
|
+
max: null,
|
|
31
|
+
step: null,
|
|
32
|
+
};
|
|
33
|
+
this.configuration = { ...this.defaults, ...data.configuration };
|
|
30
34
|
merge(this.operatorCtrl.valueChanges, this.valueCtrl.valueChanges).subscribe(() => {
|
|
31
35
|
const rendered = this.getRenderedValue();
|
|
32
36
|
this.renderedValue.next(rendered);
|
|
@@ -101,4 +105,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.1.1", ngImpor
|
|
|
101
105
|
type: Inject,
|
|
102
106
|
args: [NATURAL_DROPDOWN_DATA]
|
|
103
107
|
}] }, { type: i1.NaturalDropdownRef }]; } });
|
|
104
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"type-number.component.js","sourceRoot":"","sources":["../../../../../../../projects/natural/src/lib/modules/dropdown-components/type-number/type-number.component.ts","../../../../../../../projects/natural/src/lib/modules/dropdown-components/type-number/type-number.component.html"],"names":[],"mappings":"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","sourcesContent":["import {Component, Inject} from '@angular/core';\nimport {FormControl, FormGroup, ValidatorFn, Validators} from '@angular/forms';\nimport {BehaviorSubject, merge} from 'rxjs';\nimport {FilterGroupConditionField} from '../../search/classes/graphql-doctrine.types';\nimport {NaturalDropdownRef} from '../../search/dropdown-container/dropdown-ref';\nimport {NATURAL_DROPDOWN_DATA, NaturalDropdownData} from '../../search/dropdown-container/dropdown.service';\nimport {DropdownComponent} from '../../search/types/dropdown-component';\nimport {possibleComparableOperators, PossibleComparableOpertorKeys} from '../types';\nimport {InvalidWithValueStateMatcher} from '../type-text/type-text.component';\nimport {decimal} from '../../../classes/validators';\n\nexport interface TypeNumberConfiguration {\n    min?: number | null;\n    max?: number | null;\n    step?: number | null;\n}\n\n@Component({\n    templateUrl: './type-number.component.html',\n    styleUrls: ['./type-number.component.scss'],\n})\nexport class TypeNumberComponent implements DropdownComponent {\n    public readonly renderedValue = new BehaviorSubject<string>('');\n    public readonly configuration: TypeNumberConfiguration = {};\n    public readonly operatorCtrl = new FormControl<PossibleComparableOpertorKeys>('equal', {nonNullable: true});\n    public readonly valueCtrl = new FormControl();\n    public readonly matcher = new InvalidWithValueStateMatcher();\n    public readonly form = new FormGroup({\n        operator: this.operatorCtrl,\n        value: this.valueCtrl,\n    });\n    public readonly operators = possibleComparableOperators;\n\n    public constructor(\n        @Inject(NATURAL_DROPDOWN_DATA) data: NaturalDropdownData<TypeNumberConfiguration>,\n        protected dropdownRef: NaturalDropdownRef,\n    ) {\n        this.configuration = data.configuration || {};\n\n        merge(this.operatorCtrl.valueChanges, this.valueCtrl.valueChanges).subscribe(() => {\n            const rendered = this.getRenderedValue();\n            this.renderedValue.next(rendered);\n        });\n\n        this.initValidators();\n        this.reloadCondition(data.condition);\n    }\n\n    public getCondition(): FilterGroupConditionField {\n        const condition: FilterGroupConditionField = {};\n        condition[this.operatorCtrl.value] = {\n            value: this.valueCtrl.value,\n        };\n\n        return condition;\n    }\n\n    public isValid(): boolean {\n        return this.form.valid;\n    }\n\n    public isDirty(): boolean {\n        return this.form.dirty;\n    }\n\n    public close(): void {\n        if (this.isValid()) {\n            this.dropdownRef.close({condition: this.getCondition()});\n        } else {\n            this.dropdownRef.close(); // undefined value, discard changes / prevent to add a condition (on new fields\n        }\n    }\n\n    private initValidators(): void {\n        const validators: ValidatorFn[] = [Validators.required];\n        if (this.configuration.min) {\n            validators.push(Validators.min(this.configuration.min));\n        }\n\n        if (this.configuration.max) {\n            validators.push(Validators.max(this.configuration.max));\n        }\n\n        if (this.configuration.step) {\n            const decimals = ('' + this.configuration.step).match(/\\.(\\d+)$/)?.[1] ?? '';\n            const decimalCount = decimals.length;\n            validators.push(decimal(decimalCount));\n        }\n\n        this.valueCtrl.setValidators(validators);\n    }\n\n    private reloadCondition(condition: FilterGroupConditionField | null): void {\n        if (!condition) {\n            return;\n        }\n\n        for (const operator of this.operators) {\n            const reloadedCondition = condition[operator.key];\n            if (reloadedCondition) {\n                this.operatorCtrl.setValue(operator.key);\n                this.valueCtrl.setValue(reloadedCondition.value);\n            }\n        }\n    }\n\n    private getRenderedValue(): string {\n        const operator = this.operators.find(v => v.key === this.operatorCtrl.value);\n        if (this.valueCtrl.value === null || !operator) {\n            return '';\n        } else {\n            return operator.label + ' ' + this.valueCtrl.value;\n        }\n    }\n}\n","<form [formGroup]=\"form\">\n    <mat-form-field style=\"max-width: 4em; margin-right: 1em\">\n        <mat-label i18n=\"Mathematical operator < > =\">Opérateur</mat-label>\n        <mat-select [formControl]=\"operatorCtrl\" [required]=\"true\">\n            <mat-option *ngFor=\"let item of operators\" [value]=\"item.key\">\n                {{ item.label }}\n            </mat-option>\n        </mat-select>\n    </mat-form-field>\n\n    <mat-form-field>\n        <mat-label i18n>Valeur</mat-label>\n        <input\n            (keydown.enter)=\"close()\"\n            [errorStateMatcher]=\"matcher\"\n            [formControl]=\"valueCtrl\"\n            [attr.max]=\"configuration.max\"\n            [attr.min]=\"configuration.min\"\n            [required]=\"true\"\n            [step]=\"configuration.step\"\n            matInput\n            type=\"number\"\n        />\n        <mat-error *ngIf=\"valueCtrl.hasError('min')\">< {{ configuration.min }}</mat-error>\n        <mat-error *ngIf=\"valueCtrl.hasError('max')\">> {{ configuration.max }}</mat-error>\n    </mat-form-field>\n</form>\n"]}
|
|
108
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"type-number.component.js","sourceRoot":"","sources":["../../../../../../../projects/natural/src/lib/modules/dropdown-components/type-number/type-number.component.ts","../../../../../../../projects/natural/src/lib/modules/dropdown-components/type-number/type-number.component.html"],"names":[],"mappings":"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","sourcesContent":["import {Component, Inject} from '@angular/core';\nimport {FormControl, FormGroup, ValidatorFn, Validators} from '@angular/forms';\nimport {BehaviorSubject, merge} from 'rxjs';\nimport {FilterGroupConditionField} from '../../search/classes/graphql-doctrine.types';\nimport {NaturalDropdownRef} from '../../search/dropdown-container/dropdown-ref';\nimport {NATURAL_DROPDOWN_DATA, NaturalDropdownData} from '../../search/dropdown-container/dropdown.service';\nimport {DropdownComponent} from '../../search/types/dropdown-component';\nimport {possibleComparableOperators, PossibleComparableOpertorKeys} from '../types';\nimport {InvalidWithValueStateMatcher} from '../type-text/type-text.component';\nimport {decimal} from '../../../classes/validators';\n\nexport interface TypeNumberConfiguration {\n    min?: number | null;\n    max?: number | null;\n    step?: number | null;\n}\n\n@Component({\n    templateUrl: './type-number.component.html',\n    styleUrls: ['./type-number.component.scss'],\n})\nexport class TypeNumberComponent implements DropdownComponent {\n    public readonly renderedValue = new BehaviorSubject<string>('');\n    public readonly configuration: Required<TypeNumberConfiguration>;\n    public readonly operatorCtrl = new FormControl<PossibleComparableOpertorKeys>('equal', {nonNullable: true});\n    public readonly valueCtrl = new FormControl();\n    public readonly matcher = new InvalidWithValueStateMatcher();\n    public readonly form = new FormGroup({\n        operator: this.operatorCtrl,\n        value: this.valueCtrl,\n    });\n    public readonly operators = possibleComparableOperators;\n\n    private readonly defaults: Required<TypeNumberConfiguration> = {\n        min: null,\n        max: null,\n        step: null,\n    };\n\n    public constructor(\n        @Inject(NATURAL_DROPDOWN_DATA) data: NaturalDropdownData<TypeNumberConfiguration>,\n        protected dropdownRef: NaturalDropdownRef,\n    ) {\n        this.configuration = {...this.defaults, ...data.configuration};\n\n        merge(this.operatorCtrl.valueChanges, this.valueCtrl.valueChanges).subscribe(() => {\n            const rendered = this.getRenderedValue();\n            this.renderedValue.next(rendered);\n        });\n\n        this.initValidators();\n        this.reloadCondition(data.condition);\n    }\n\n    public getCondition(): FilterGroupConditionField {\n        const condition: FilterGroupConditionField = {};\n        condition[this.operatorCtrl.value] = {\n            value: this.valueCtrl.value,\n        };\n\n        return condition;\n    }\n\n    public isValid(): boolean {\n        return this.form.valid;\n    }\n\n    public isDirty(): boolean {\n        return this.form.dirty;\n    }\n\n    public close(): void {\n        if (this.isValid()) {\n            this.dropdownRef.close({condition: this.getCondition()});\n        } else {\n            this.dropdownRef.close(); // undefined value, discard changes / prevent to add a condition (on new fields\n        }\n    }\n\n    private initValidators(): void {\n        const validators: ValidatorFn[] = [Validators.required];\n        if (this.configuration.min) {\n            validators.push(Validators.min(this.configuration.min));\n        }\n\n        if (this.configuration.max) {\n            validators.push(Validators.max(this.configuration.max));\n        }\n\n        if (this.configuration.step) {\n            const decimals = ('' + this.configuration.step).match(/\\.(\\d+)$/)?.[1] ?? '';\n            const decimalCount = decimals.length;\n            validators.push(decimal(decimalCount));\n        }\n\n        this.valueCtrl.setValidators(validators);\n    }\n\n    private reloadCondition(condition: FilterGroupConditionField | null): void {\n        if (!condition) {\n            return;\n        }\n\n        for (const operator of this.operators) {\n            const reloadedCondition = condition[operator.key];\n            if (reloadedCondition) {\n                this.operatorCtrl.setValue(operator.key);\n                this.valueCtrl.setValue(reloadedCondition.value);\n            }\n        }\n    }\n\n    private getRenderedValue(): string {\n        const operator = this.operators.find(v => v.key === this.operatorCtrl.value);\n        if (this.valueCtrl.value === null || !operator) {\n            return '';\n        } else {\n            return operator.label + ' ' + this.valueCtrl.value;\n        }\n    }\n}\n","<form [formGroup]=\"form\">\n    <mat-form-field style=\"max-width: 4em; margin-right: 1em\">\n        <mat-label i18n=\"Mathematical operator < > =\">Opérateur</mat-label>\n        <mat-select [formControl]=\"operatorCtrl\" [required]=\"true\">\n            <mat-option *ngFor=\"let item of operators\" [value]=\"item.key\">\n                {{ item.label }}\n            </mat-option>\n        </mat-select>\n    </mat-form-field>\n\n    <mat-form-field>\n        <mat-label i18n>Valeur</mat-label>\n        <input\n            (keydown.enter)=\"close()\"\n            [errorStateMatcher]=\"matcher\"\n            [formControl]=\"valueCtrl\"\n            [attr.max]=\"configuration.max\"\n            [attr.min]=\"configuration.min\"\n            [required]=\"true\"\n            [step]=\"configuration.step\"\n            matInput\n            type=\"number\"\n        />\n        <mat-error *ngIf=\"valueCtrl.hasError('min')\">< {{ configuration.min }}</mat-error>\n        <mat-error *ngIf=\"valueCtrl.hasError('max')\">> {{ configuration.max }}</mat-error>\n    </mat-form-field>\n</form>\n"]}
|
|
@@ -29,6 +29,7 @@ export class TypeSelectComponent extends NaturalAbstractController {
|
|
|
29
29
|
this.defaults = {
|
|
30
30
|
items: [],
|
|
31
31
|
multiple: true,
|
|
32
|
+
operators: true,
|
|
32
33
|
};
|
|
33
34
|
this.configuration = { ...this.defaults, ...data.configuration };
|
|
34
35
|
// Immediately initValidators and everytime the operator change later
|
|
@@ -77,7 +78,7 @@ export class TypeSelectComponent extends NaturalAbstractController {
|
|
|
77
78
|
this.valueCtrl.updateValueAndValidity();
|
|
78
79
|
}
|
|
79
80
|
isMultiple() {
|
|
80
|
-
return
|
|
81
|
+
return this.configuration.multiple;
|
|
81
82
|
}
|
|
82
83
|
getItemById(id) {
|
|
83
84
|
return this.items.find(item => this.getId(item) === id);
|
|
@@ -105,7 +106,7 @@ export class TypeSelectComponent extends NaturalAbstractController {
|
|
|
105
106
|
this.items = items;
|
|
106
107
|
// Reload selection, according to possible values from configuration
|
|
107
108
|
const possibleIds = this.items.map(item => this.getId(item));
|
|
108
|
-
const wantedAndPossibleIds = wantedIds.filter(id =>
|
|
109
|
+
const wantedAndPossibleIds = wantedIds.filter(id => possibleIds.some(i => i === id));
|
|
109
110
|
return wantedAndPossibleIds;
|
|
110
111
|
}));
|
|
111
112
|
}
|
|
@@ -125,6 +126,9 @@ export class TypeSelectComponent extends NaturalAbstractController {
|
|
|
125
126
|
return [operator.label, selection].filter(v => v).join(' ');
|
|
126
127
|
}
|
|
127
128
|
conditionToOperatorKey(condition) {
|
|
129
|
+
if (!this.configuration.operators) {
|
|
130
|
+
return 'is';
|
|
131
|
+
}
|
|
128
132
|
if (condition.in && !condition.in.not) {
|
|
129
133
|
return 'is';
|
|
130
134
|
}
|
|
@@ -155,10 +159,10 @@ export class TypeSelectComponent extends NaturalAbstractController {
|
|
|
155
159
|
}
|
|
156
160
|
}
|
|
157
161
|
TypeSelectComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.1.1", ngImport: i0, type: TypeSelectComponent, deps: [{ token: NATURAL_DROPDOWN_DATA }], target: i0.ɵɵFactoryTarget.Component });
|
|
158
|
-
TypeSelectComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.1.1", type: TypeSelectComponent, selector: "ng-component", viewQueries: [{ propertyName: "list", first: true, predicate: MatSelectionList, descendants: true }], usesInheritance: true, ngImport: i0, template: "<form [formGroup]=\"form\">\n <mat-form-field style=\"max-width: 7em; margin-right: 1em\">\n <mat-label i18n=\"Mathematical operator < > =\">Op\u00E9rateur</mat-label>\n <mat-select [formControl]=\"operatorCtrl\" [required]=\"true\">\n <mat-option *ngFor=\"let item of operators\" [value]=\"item.key\">\n {{ item.label }}\n </mat-option>\n </mat-select>\n </mat-form-field>\n\n <mat-selection-list *ngIf=\"requireValueCtrl\" [formControl]=\"valueCtrl\">\n <mat-list-option *ngFor=\"let item of items\" [value]=\"getId(item)\" checkboxPosition=\"before\">\n {{ getDisplay(item) }}\n </mat-list-option>\n </mat-selection-list>\n</form>\n", dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i2.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { kind: "component", type: i3.MatFormField, selector: "mat-form-field", inputs: ["color", "appearance", "hideRequiredMarker", "hintLabel", "floatLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i3.MatLabel, selector: "mat-label" }, { kind: "directive", type: i2.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "directive", type: i2.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "component", type: i4.MatSelectionList, selector: "mat-selection-list", inputs: ["disableRipple", "color", "compareWith", "disabled", "multiple"], outputs: ["selectionChange"], exportAs: ["matSelectionList"] }, { kind: "component", type: i4.MatListOption, selector: "mat-list-option", inputs: ["disableRipple", "checkboxPosition", "color", "value", "disabled", "selected"], outputs: ["selectedChange"], exportAs: ["matListOption"] }, { kind: "component", type: i5.MatSelect, selector: "mat-select", inputs: ["disabled", "disableRipple", "tabIndex"], exportAs: ["matSelect"] }, { kind: "component", type: i6.MatOption, selector: "mat-option", exportAs: ["matOption"] }] });
|
|
162
|
+
TypeSelectComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.1.1", type: TypeSelectComponent, selector: "ng-component", viewQueries: [{ propertyName: "list", first: true, predicate: MatSelectionList, descendants: true }], usesInheritance: true, ngImport: i0, template: "<form [formGroup]=\"form\">\n <mat-form-field style=\"max-width: 7em; margin-right: 1em\" *ngIf=\"configuration.operators\">\n <mat-label i18n=\"Mathematical operator < > =\">Op\u00E9rateur</mat-label>\n <mat-select [formControl]=\"operatorCtrl\" [required]=\"true\">\n <mat-option *ngFor=\"let item of operators\" [value]=\"item.key\">\n {{ item.label }}\n </mat-option>\n </mat-select>\n </mat-form-field>\n\n <mat-selection-list *ngIf=\"requireValueCtrl\" [formControl]=\"valueCtrl\">\n <mat-list-option *ngFor=\"let item of items\" [value]=\"getId(item)\" checkboxPosition=\"before\">\n {{ getDisplay(item) }}\n </mat-list-option>\n </mat-selection-list>\n</form>\n", dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i2.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { kind: "component", type: i3.MatFormField, selector: "mat-form-field", inputs: ["color", "appearance", "hideRequiredMarker", "hintLabel", "floatLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i3.MatLabel, selector: "mat-label" }, { kind: "directive", type: i2.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "directive", type: i2.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "component", type: i4.MatSelectionList, selector: "mat-selection-list", inputs: ["disableRipple", "color", "compareWith", "disabled", "multiple"], outputs: ["selectionChange"], exportAs: ["matSelectionList"] }, { kind: "component", type: i4.MatListOption, selector: "mat-list-option", inputs: ["disableRipple", "checkboxPosition", "color", "value", "disabled", "selected"], outputs: ["selectedChange"], exportAs: ["matListOption"] }, { kind: "component", type: i5.MatSelect, selector: "mat-select", inputs: ["disabled", "disableRipple", "tabIndex"], exportAs: ["matSelect"] }, { kind: "component", type: i6.MatOption, selector: "mat-option", exportAs: ["matOption"] }] });
|
|
159
163
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.1.1", ngImport: i0, type: TypeSelectComponent, decorators: [{
|
|
160
164
|
type: Component,
|
|
161
|
-
args: [{ template: "<form [formGroup]=\"form\">\n <mat-form-field style=\"max-width: 7em; margin-right: 1em\">\n <mat-label i18n=\"Mathematical operator < > =\">Op\u00E9rateur</mat-label>\n <mat-select [formControl]=\"operatorCtrl\" [required]=\"true\">\n <mat-option *ngFor=\"let item of operators\" [value]=\"item.key\">\n {{ item.label }}\n </mat-option>\n </mat-select>\n </mat-form-field>\n\n <mat-selection-list *ngIf=\"requireValueCtrl\" [formControl]=\"valueCtrl\">\n <mat-list-option *ngFor=\"let item of items\" [value]=\"getId(item)\" checkboxPosition=\"before\">\n {{ getDisplay(item) }}\n </mat-list-option>\n </mat-selection-list>\n</form>\n" }]
|
|
165
|
+
args: [{ template: "<form [formGroup]=\"form\">\n <mat-form-field style=\"max-width: 7em; margin-right: 1em\" *ngIf=\"configuration.operators\">\n <mat-label i18n=\"Mathematical operator < > =\">Op\u00E9rateur</mat-label>\n <mat-select [formControl]=\"operatorCtrl\" [required]=\"true\">\n <mat-option *ngFor=\"let item of operators\" [value]=\"item.key\">\n {{ item.label }}\n </mat-option>\n </mat-select>\n </mat-form-field>\n\n <mat-selection-list *ngIf=\"requireValueCtrl\" [formControl]=\"valueCtrl\">\n <mat-list-option *ngFor=\"let item of items\" [value]=\"getId(item)\" checkboxPosition=\"before\">\n {{ getDisplay(item) }}\n </mat-list-option>\n </mat-selection-list>\n</form>\n" }]
|
|
162
166
|
}], ctorParameters: function () { return [{ type: undefined, decorators: [{
|
|
163
167
|
type: Inject,
|
|
164
168
|
args: [NATURAL_DROPDOWN_DATA]
|
|
@@ -166,4 +170,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.1.1", ngImpor
|
|
|
166
170
|
type: ViewChild,
|
|
167
171
|
args: [MatSelectionList, { static: false }]
|
|
168
172
|
}] } });
|
|
169
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"type-select.component.js","sourceRoot":"","sources":["../../../../../../../projects/natural/src/lib/modules/dropdown-components/type-select/type-select.component.ts","../../../../../../../projects/natural/src/lib/modules/dropdown-components/type-select/type-select.component.html"],"names":[],"mappings":"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","sourcesContent":["import {AfterViewInit, Component, Inject, OnDestroy, ViewChild} from '@angular/core';\nimport {MatSelectionList} from '@angular/material/list';\nimport {BehaviorSubject, merge, Observable, of} from 'rxjs';\nimport {FilterGroupConditionField, Scalar} from '../../search/classes/graphql-doctrine.types';\nimport {NATURAL_DROPDOWN_DATA, NaturalDropdownData} from '../../search/dropdown-container/dropdown.service';\nimport {DropdownComponent} from '../../search/types/dropdown-component';\nimport {FormControl, FormGroup, ValidatorFn, Validators} from '@angular/forms';\nimport {NaturalAbstractController} from '../../../classes/abstract-controller';\nimport {map, startWith, takeUntil} from 'rxjs/operators';\nimport {PossibleDiscreteOperator, PossibleDiscreteOperatorKeys, possibleDiscreteOperators} from '../types';\n\nexport type TypeSelectItem =\n    | Scalar\n    | {\n          id: Scalar;\n          name: Scalar;\n      }\n    | {\n          value: Scalar;\n          name: Scalar;\n      };\n\nexport interface TypeSelectConfiguration {\n    items: TypeSelectItem[] | Observable<TypeSelectItem[]>;\n    multiple?: boolean;\n}\n\n@Component({\n    templateUrl: './type-select.component.html',\n})\nexport class TypeSelectComponent\n    extends NaturalAbstractController\n    implements DropdownComponent, AfterViewInit, OnDestroy\n{\n    public readonly renderedValue = new BehaviorSubject<string>('');\n    @ViewChild(MatSelectionList, {static: false}) public list!: MatSelectionList;\n    public requireValueCtrl = false;\n    public readonly operators = possibleDiscreteOperators;\n    public readonly operatorCtrl = new FormControl<PossibleDiscreteOperatorKeys>('is', {nonNullable: true});\n    public readonly valueCtrl = new FormControl();\n    public readonly form = new FormGroup({\n        operator: this.operatorCtrl,\n        value: this.valueCtrl,\n    });\n\n    public items: TypeSelectItem[] = [];\n    private readonly configuration: TypeSelectConfiguration;\n\n    private readonly defaults: TypeSelectConfiguration = {\n        items: [],\n        multiple: true,\n    };\n\n    public constructor(@Inject(NATURAL_DROPDOWN_DATA) data: NaturalDropdownData<TypeSelectConfiguration>) {\n        super();\n        this.configuration = {...this.defaults, ...data.configuration};\n\n        // Immediately initValidators and everytime the operator change later\n        this.operatorCtrl.valueChanges.pipe(startWith(null)).subscribe(() => this.initValidators());\n\n        merge(this.operatorCtrl.valueChanges, this.valueCtrl.valueChanges).subscribe(() => {\n            const rendered = this.getRenderedValue();\n            this.renderedValue.next(rendered);\n        });\n\n        this.reloadCondition(data.condition);\n    }\n\n    public ngAfterViewInit(): void {\n        if (!this.isMultiple() && this.list) {\n            (this.list.selectedOptions as any)._multiple = false;\n        }\n    }\n\n    public getId(item: TypeSelectItem): Scalar {\n        if (typeof item === 'object' && item) {\n            return (item as any).id || (item as any).value;\n        }\n\n        return item as Scalar;\n    }\n\n    public getDisplay(item: TypeSelectItem): Scalar {\n        if (typeof item === 'object' && item && item.name) {\n            return item.name;\n        }\n\n        return item as Scalar;\n    }\n\n    public getCondition(): FilterGroupConditionField {\n        if (!this.isValid()) {\n            return {};\n        }\n\n        const values = this.valueCtrl.value;\n        return this.operatorKeyToCondition(this.operatorCtrl.value, values);\n    }\n\n    public isValid(): boolean {\n        return this.form.valid;\n    }\n\n    public isDirty(): boolean {\n        return this.form.dirty;\n    }\n\n    private initValidators(): void {\n        const whitelist: PossibleDiscreteOperatorKeys[] = ['is', 'isnot'];\n        this.requireValueCtrl = whitelist.includes(this.operatorCtrl.value);\n        const validators: ValidatorFn[] = this.requireValueCtrl ? [Validators.required] : [];\n\n        this.valueCtrl.setValidators(validators);\n        this.valueCtrl.updateValueAndValidity();\n    }\n\n    private isMultiple(): boolean {\n        return !!this.configuration.multiple;\n    }\n\n    private getItemById(id: Scalar): TypeSelectItem | undefined {\n        return this.items.find(item => this.getId(item) === id);\n    }\n\n    private reloadCondition(condition: FilterGroupConditionField | null): void {\n        if (condition) {\n            const operatorKey = this.conditionToOperatorKey(condition);\n            this.operatorCtrl.setValue(operatorKey);\n        }\n\n        // Always reload value, even without condition because we need to load list of available items in all cases\n        this.reloadValue(condition).subscribe(value => {\n            this.valueCtrl.setValue(value);\n            this.renderedValue.next(this.getRenderedValue());\n        });\n    }\n\n    /**\n     * Reload the value from API (`operatorCtrl` should not be touched)\n     */\n    private reloadValue(condition: FilterGroupConditionField | null): Observable<Scalar[]> {\n        const wantedIds = condition?.in?.values ?? [];\n\n        const items$ = Array.isArray(this.configuration.items)\n            ? of(this.configuration.items)\n            : this.configuration.items;\n\n        return items$.pipe(\n            takeUntil(this.ngUnsubscribe),\n            map(items => {\n                this.items = items;\n\n                // Reload selection, according to possible values from configuration\n                const possibleIds = this.items.map(item => this.getId(item));\n                const wantedAndPossibleIds = wantedIds.filter(\n                    id => typeof possibleIds.find(i => i === id) !== 'undefined',\n                );\n\n                return wantedAndPossibleIds;\n            }),\n        );\n    }\n\n    private getRenderedValue(): string {\n        const operator = this.operators.find(v => v.key === this.operatorCtrl.value);\n        if (!operator || !this.isValid()) {\n            return '';\n        }\n\n        const selection =\n            this.valueCtrl.value\n                ?.map((id: Scalar) => {\n                    const item = this.getItemById(id);\n                    if (item) {\n                        return this.getDisplay(item);\n                    }\n                })\n                .join(', ') ?? null;\n\n        return [operator.label, selection].filter(v => v).join(' ');\n    }\n\n    private conditionToOperatorKey(condition: FilterGroupConditionField): PossibleDiscreteOperatorKeys {\n        if (condition.in && !condition.in.not) {\n            return 'is';\n        } else if (condition.in && condition.in.not) {\n            return 'isnot';\n        } else if (condition.null && condition.null.not) {\n            return 'any';\n        } else if (condition.null && !condition.null.not) {\n            return 'none';\n        }\n\n        return 'is';\n    }\n\n    private operatorKeyToCondition(key: PossibleDiscreteOperatorKeys, values: Scalar[]): FilterGroupConditionField {\n        switch (key) {\n            case 'is':\n                return {in: {values: values}};\n            case 'isnot':\n                return {in: {values: values, not: true}};\n            case 'any':\n                return {null: {not: true}};\n            case 'none':\n                return {null: {not: false}};\n            default:\n                throw new Error('Unsupported operator key: ' + key);\n        }\n    }\n}\n","<form [formGroup]=\"form\">\n    <mat-form-field style=\"max-width: 7em; margin-right: 1em\">\n        <mat-label i18n=\"Mathematical operator < > =\">Opérateur</mat-label>\n        <mat-select [formControl]=\"operatorCtrl\" [required]=\"true\">\n            <mat-option *ngFor=\"let item of operators\" [value]=\"item.key\">\n                {{ item.label }}\n            </mat-option>\n        </mat-select>\n    </mat-form-field>\n\n    <mat-selection-list *ngIf=\"requireValueCtrl\" [formControl]=\"valueCtrl\">\n        <mat-list-option *ngFor=\"let item of items\" [value]=\"getId(item)\" checkboxPosition=\"before\">\n            {{ getDisplay(item) }}\n        </mat-list-option>\n    </mat-selection-list>\n</form>\n"]}
|
|
173
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"type-select.component.js","sourceRoot":"","sources":["../../../../../../../projects/natural/src/lib/modules/dropdown-components/type-select/type-select.component.ts","../../../../../../../projects/natural/src/lib/modules/dropdown-components/type-select/type-select.component.html"],"names":[],"mappings":"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","sourcesContent":["import {AfterViewInit, Component, Inject, OnDestroy, ViewChild} from '@angular/core';\nimport {MatSelectionList} from '@angular/material/list';\nimport {BehaviorSubject, merge, Observable, of} from 'rxjs';\nimport {FilterGroupConditionField, Scalar} from '../../search/classes/graphql-doctrine.types';\nimport {NATURAL_DROPDOWN_DATA, NaturalDropdownData} from '../../search/dropdown-container/dropdown.service';\nimport {DropdownComponent} from '../../search/types/dropdown-component';\nimport {FormControl, FormGroup, ValidatorFn, Validators} from '@angular/forms';\nimport {NaturalAbstractController} from '../../../classes/abstract-controller';\nimport {map, startWith, takeUntil} from 'rxjs/operators';\nimport {PossibleDiscreteOperatorKeys, possibleDiscreteOperators} from '../types';\n\nexport type TypeSelectItem =\n    | Scalar\n    | {\n          id: Scalar;\n          name: Scalar;\n      }\n    | {\n          value: Scalar;\n          name: Scalar;\n      };\n\nexport interface TypeSelectConfiguration {\n    items: TypeSelectItem[] | Observable<TypeSelectItem[]>;\n    multiple?: boolean;\n    /**\n     * If true (default) a selectbox allows to choose an operator. Otherwise, the selectbox is hidden and the operator will always be `is`.\n     */\n    operators?: boolean;\n}\n\n@Component({\n    templateUrl: './type-select.component.html',\n})\nexport class TypeSelectComponent\n    extends NaturalAbstractController\n    implements DropdownComponent, AfterViewInit, OnDestroy\n{\n    public readonly renderedValue = new BehaviorSubject<string>('');\n    @ViewChild(MatSelectionList, {static: false}) public list!: MatSelectionList;\n    public requireValueCtrl = false;\n    public readonly operators = possibleDiscreteOperators;\n    public readonly operatorCtrl = new FormControl<PossibleDiscreteOperatorKeys>('is', {nonNullable: true});\n    public readonly valueCtrl = new FormControl();\n    public readonly form = new FormGroup({\n        operator: this.operatorCtrl,\n        value: this.valueCtrl,\n    });\n\n    public items: TypeSelectItem[] = [];\n    public readonly configuration: Required<TypeSelectConfiguration>;\n\n    private readonly defaults: Required<TypeSelectConfiguration> = {\n        items: [],\n        multiple: true,\n        operators: true,\n    };\n\n    public constructor(@Inject(NATURAL_DROPDOWN_DATA) data: NaturalDropdownData<TypeSelectConfiguration>) {\n        super();\n        this.configuration = {...this.defaults, ...data.configuration};\n\n        // Immediately initValidators and everytime the operator change later\n        this.operatorCtrl.valueChanges.pipe(startWith(null)).subscribe(() => this.initValidators());\n\n        merge(this.operatorCtrl.valueChanges, this.valueCtrl.valueChanges).subscribe(() => {\n            const rendered = this.getRenderedValue();\n            this.renderedValue.next(rendered);\n        });\n\n        this.reloadCondition(data.condition);\n    }\n\n    public ngAfterViewInit(): void {\n        if (!this.isMultiple() && this.list) {\n            (this.list.selectedOptions as any)._multiple = false;\n        }\n    }\n\n    public getId(item: TypeSelectItem): Scalar {\n        if (typeof item === 'object' && item) {\n            return (item as any).id || (item as any).value;\n        }\n\n        return item as Scalar;\n    }\n\n    public getDisplay(item: TypeSelectItem): Scalar {\n        if (typeof item === 'object' && item && item.name) {\n            return item.name;\n        }\n\n        return item as Scalar;\n    }\n\n    public getCondition(): FilterGroupConditionField {\n        if (!this.isValid()) {\n            return {};\n        }\n\n        const values = this.valueCtrl.value;\n        return this.operatorKeyToCondition(this.operatorCtrl.value, values);\n    }\n\n    public isValid(): boolean {\n        return this.form.valid;\n    }\n\n    public isDirty(): boolean {\n        return this.form.dirty;\n    }\n\n    private initValidators(): void {\n        const whitelist: PossibleDiscreteOperatorKeys[] = ['is', 'isnot'];\n        this.requireValueCtrl = whitelist.includes(this.operatorCtrl.value);\n        const validators: ValidatorFn[] = this.requireValueCtrl ? [Validators.required] : [];\n\n        this.valueCtrl.setValidators(validators);\n        this.valueCtrl.updateValueAndValidity();\n    }\n\n    private isMultiple(): boolean {\n        return this.configuration.multiple;\n    }\n\n    private getItemById(id: Scalar): TypeSelectItem | undefined {\n        return this.items.find(item => this.getId(item) === id);\n    }\n\n    private reloadCondition(condition: FilterGroupConditionField | null): void {\n        if (condition) {\n            const operatorKey = this.conditionToOperatorKey(condition);\n            this.operatorCtrl.setValue(operatorKey);\n        }\n\n        // Always reload value, even without condition because we need to load list of available items in all cases\n        this.reloadValue(condition).subscribe(value => {\n            this.valueCtrl.setValue(value);\n            this.renderedValue.next(this.getRenderedValue());\n        });\n    }\n\n    /**\n     * Reload the value from API (`operatorCtrl` should not be touched)\n     */\n    private reloadValue(condition: FilterGroupConditionField | null): Observable<Scalar[]> {\n        const wantedIds = condition?.in?.values ?? [];\n\n        const items$ = Array.isArray(this.configuration.items)\n            ? of(this.configuration.items)\n            : this.configuration.items;\n\n        return items$.pipe(\n            takeUntil(this.ngUnsubscribe),\n            map(items => {\n                this.items = items;\n\n                // Reload selection, according to possible values from configuration\n                const possibleIds = this.items.map(item => this.getId(item));\n                const wantedAndPossibleIds = wantedIds.filter(id => possibleIds.some(i => i === id));\n\n                return wantedAndPossibleIds;\n            }),\n        );\n    }\n\n    private getRenderedValue(): string {\n        const operator = this.operators.find(v => v.key === this.operatorCtrl.value);\n        if (!operator || !this.isValid()) {\n            return '';\n        }\n\n        const selection =\n            this.valueCtrl.value\n                ?.map((id: Scalar) => {\n                    const item = this.getItemById(id);\n                    if (item) {\n                        return this.getDisplay(item);\n                    }\n                })\n                .join(', ') ?? null;\n\n        return [operator.label, selection].filter(v => v).join(' ');\n    }\n\n    private conditionToOperatorKey(condition: FilterGroupConditionField): PossibleDiscreteOperatorKeys {\n        if (!this.configuration.operators) {\n            return 'is';\n        }\n\n        if (condition.in && !condition.in.not) {\n            return 'is';\n        } else if (condition.in && condition.in.not) {\n            return 'isnot';\n        } else if (condition.null && condition.null.not) {\n            return 'any';\n        } else if (condition.null && !condition.null.not) {\n            return 'none';\n        }\n\n        return 'is';\n    }\n\n    private operatorKeyToCondition(key: PossibleDiscreteOperatorKeys, values: Scalar[]): FilterGroupConditionField {\n        switch (key) {\n            case 'is':\n                return {in: {values: values}};\n            case 'isnot':\n                return {in: {values: values, not: true}};\n            case 'any':\n                return {null: {not: true}};\n            case 'none':\n                return {null: {not: false}};\n            default:\n                throw new Error('Unsupported operator key: ' + key);\n        }\n    }\n}\n","<form [formGroup]=\"form\">\n    <mat-form-field style=\"max-width: 7em; margin-right: 1em\" *ngIf=\"configuration.operators\">\n        <mat-label i18n=\"Mathematical operator < > =\">Opérateur</mat-label>\n        <mat-select [formControl]=\"operatorCtrl\" [required]=\"true\">\n            <mat-option *ngFor=\"let item of operators\" [value]=\"item.key\">\n                {{ item.label }}\n            </mat-option>\n        </mat-select>\n    </mat-form-field>\n\n    <mat-selection-list *ngIf=\"requireValueCtrl\" [formControl]=\"valueCtrl\">\n        <mat-list-option *ngFor=\"let item of items\" [value]=\"getId(item)\" checkboxPosition=\"before\">\n            {{ getDisplay(item) }}\n        </mat-list-option>\n    </mat-selection-list>\n</form>\n"]}
|
|
@@ -1,16 +1,19 @@
|
|
|
1
1
|
import { Component, EventEmitter, Input, Output } from '@angular/core';
|
|
2
|
+
import { NaturalAbstractController } from '../../classes/abstract-controller';
|
|
3
|
+
import { takeUntil } from 'rxjs';
|
|
2
4
|
import * as i0 from "@angular/core";
|
|
3
5
|
import * as i1 from "@angular/router";
|
|
4
6
|
import * as i2 from "@angular/common";
|
|
5
7
|
import * as i3 from "../fixed-button/fixed-button.component";
|
|
6
8
|
import * as i4 from "@angular/material/tooltip";
|
|
7
|
-
export class NaturalFixedButtonDetailComponent {
|
|
9
|
+
export class NaturalFixedButtonDetailComponent extends NaturalAbstractController {
|
|
8
10
|
constructor(route) {
|
|
11
|
+
super();
|
|
9
12
|
this.canChange = true;
|
|
10
13
|
this.isCreation = false;
|
|
11
14
|
this.create = new EventEmitter();
|
|
12
15
|
this.delete = new EventEmitter();
|
|
13
|
-
route.params.subscribe(() => (this.canChange = true));
|
|
16
|
+
route.params.pipe(takeUntil(this.ngUnsubscribe)).subscribe(() => (this.canChange = true));
|
|
14
17
|
}
|
|
15
18
|
get model() {
|
|
16
19
|
return this._model;
|
|
@@ -19,6 +22,7 @@ export class NaturalFixedButtonDetailComponent {
|
|
|
19
22
|
this._model = value;
|
|
20
23
|
if (this.canChange) {
|
|
21
24
|
this.isCreation = !this._model.id;
|
|
25
|
+
this.canChange = false;
|
|
22
26
|
}
|
|
23
27
|
}
|
|
24
28
|
clickCreate() {
|
|
@@ -33,7 +37,7 @@ export class NaturalFixedButtonDetailComponent {
|
|
|
33
37
|
}
|
|
34
38
|
}
|
|
35
39
|
NaturalFixedButtonDetailComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.1.1", ngImport: i0, type: NaturalFixedButtonDetailComponent, deps: [{ token: i1.ActivatedRoute }], target: i0.ɵɵFactoryTarget.Component });
|
|
36
|
-
NaturalFixedButtonDetailComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.1.1", type: NaturalFixedButtonDetailComponent, selector: "natural-fixed-button-detail", inputs: { model: "model", form: "form" }, outputs: { create: "create", delete: "delete" }, ngImport: i0, template: "<natural-fixed-button\n (click)=\"clickCreate()\"\n *ngIf=\"isCreation\"\n [disabled]=\"form.disabled\"\n [color]=\"form.valid ? 'accent' : 'warn'\"\n class=\"detail-speed-dial\"\n icon=\"save\"\n></natural-fixed-button>\n\n<natural-fixed-button\n (click)=\"clickDelete()\"\n *ngIf=\"!isCreation && (!model.permissions || model.permissions.delete)\"\n [disabled]=\"form.disabled\"\n class=\"detail-speed-dial\"\n color=\"warn\"\n icon=\"delete_forever\"\n i18n-matTooltip\n matTooltip=\"Supprimer d\u00E9finitivement\"\n matTooltipPosition=\"left\"\n></natural-fixed-button>\n", styles: [""], dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i3.NaturalFixedButtonComponent, selector: "natural-fixed-button", inputs: ["icon", "link", "color", "disabled"] }, { kind: "directive", type: i4.MatTooltip, selector: "[matTooltip]", exportAs: ["matTooltip"] }] });
|
|
40
|
+
NaturalFixedButtonDetailComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.1.1", type: NaturalFixedButtonDetailComponent, selector: "natural-fixed-button-detail", inputs: { model: "model", form: "form" }, outputs: { create: "create", delete: "delete" }, usesInheritance: true, ngImport: i0, template: "<natural-fixed-button\n (click)=\"clickCreate()\"\n *ngIf=\"isCreation\"\n [disabled]=\"form.disabled\"\n [color]=\"form.valid ? 'accent' : 'warn'\"\n class=\"detail-speed-dial\"\n icon=\"save\"\n></natural-fixed-button>\n\n<natural-fixed-button\n (click)=\"clickDelete()\"\n *ngIf=\"!isCreation && (!model.permissions || model.permissions.delete)\"\n [disabled]=\"form.disabled\"\n class=\"detail-speed-dial\"\n color=\"warn\"\n icon=\"delete_forever\"\n i18n-matTooltip\n matTooltip=\"Supprimer d\u00E9finitivement\"\n matTooltipPosition=\"left\"\n></natural-fixed-button>\n", styles: [""], dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i3.NaturalFixedButtonComponent, selector: "natural-fixed-button", inputs: ["icon", "link", "color", "disabled"] }, { kind: "directive", type: i4.MatTooltip, selector: "[matTooltip]", exportAs: ["matTooltip"] }] });
|
|
37
41
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.1.1", ngImport: i0, type: NaturalFixedButtonDetailComponent, decorators: [{
|
|
38
42
|
type: Component,
|
|
39
43
|
args: [{ selector: 'natural-fixed-button-detail', template: "<natural-fixed-button\n (click)=\"clickCreate()\"\n *ngIf=\"isCreation\"\n [disabled]=\"form.disabled\"\n [color]=\"form.valid ? 'accent' : 'warn'\"\n class=\"detail-speed-dial\"\n icon=\"save\"\n></natural-fixed-button>\n\n<natural-fixed-button\n (click)=\"clickDelete()\"\n *ngIf=\"!isCreation && (!model.permissions || model.permissions.delete)\"\n [disabled]=\"form.disabled\"\n class=\"detail-speed-dial\"\n color=\"warn\"\n icon=\"delete_forever\"\n i18n-matTooltip\n matTooltip=\"Supprimer d\u00E9finitivement\"\n matTooltipPosition=\"left\"\n></natural-fixed-button>\n" }]
|
|
@@ -46,4 +50,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.1.1", ngImpor
|
|
|
46
50
|
}], delete: [{
|
|
47
51
|
type: Output
|
|
48
52
|
}] } });
|
|
49
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
53
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZml4ZWQtYnV0dG9uLWRldGFpbC5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uYXR1cmFsL3NyYy9saWIvbW9kdWxlcy9maXhlZC1idXR0b24tZGV0YWlsL2ZpeGVkLWJ1dHRvbi1kZXRhaWwuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmF0dXJhbC9zcmMvbGliL21vZHVsZXMvZml4ZWQtYnV0dG9uLWRldGFpbC9maXhlZC1idXR0b24tZGV0YWlsLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQyxTQUFTLEVBQUUsWUFBWSxFQUFFLEtBQUssRUFBRSxNQUFNLEVBQUMsTUFBTSxlQUFlLENBQUM7QUFHckUsT0FBTyxFQUFDLHlCQUF5QixFQUFDLE1BQU0sbUNBQW1DLENBQUM7QUFDNUUsT0FBTyxFQUFDLFNBQVMsRUFBQyxNQUFNLE1BQU0sQ0FBQzs7Ozs7O0FBYy9CLE1BQU0sT0FBTyxpQ0FBa0MsU0FBUSx5QkFBeUI7SUF3QjVFLFlBQW1CLEtBQXFCO1FBQ3BDLEtBQUssRUFBRSxDQUFDO1FBeEJKLGNBQVMsR0FBRyxJQUFJLENBQUM7UUFDbEIsZUFBVSxHQUFHLEtBQUssQ0FBQztRQW1CQSxXQUFNLEdBQUcsSUFBSSxZQUFZLEVBQVEsQ0FBQztRQUNsQyxXQUFNLEdBQUcsSUFBSSxZQUFZLEVBQVEsQ0FBQztRQUl4RCxLQUFLLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDLGFBQWEsQ0FBQyxDQUFDLENBQUMsU0FBUyxDQUFDLEdBQUcsRUFBRSxDQUFDLENBQUMsSUFBSSxDQUFDLFNBQVMsR0FBRyxJQUFJLENBQUMsQ0FBQyxDQUFDO0lBQzlGLENBQUM7SUF2QkQsSUFBVyxLQUFLO1FBQ1osT0FBTyxJQUFJLENBQUMsTUFBTSxDQUFDO0lBQ3ZCLENBQUM7SUFFRCxJQUNXLEtBQUssQ0FBQyxLQUFZO1FBQ3pCLElBQUksQ0FBQyxNQUFNLEdBQUcsS0FBSyxDQUFDO1FBQ3BCLElBQUksSUFBSSxDQUFDLFNBQVMsRUFBRTtZQUNoQixJQUFJLENBQUMsVUFBVSxHQUFHLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxFQUFFLENBQUM7WUFDbEMsSUFBSSxDQUFDLFNBQVMsR0FBRyxLQUFLLENBQUM7U0FDMUI7SUFDTCxDQUFDO0lBY00sV0FBVztRQUNkLElBQUksSUFBSSxDQUFDLElBQUksQ0FBQyxPQUFPLEVBQUU7WUFDbkIsSUFBSSxDQUFDLE1BQU0sQ0FBQyxJQUFJLEVBQUUsQ0FBQztTQUN0QjtJQUNMLENBQUM7SUFFTSxXQUFXO1FBQ2QsSUFBSSxJQUFJLENBQUMsSUFBSSxDQUFDLE9BQU8sRUFBRTtZQUNuQixJQUFJLENBQUMsTUFBTSxDQUFDLElBQUksRUFBRSxDQUFDO1NBQ3RCO0lBQ0wsQ0FBQzs7OEhBdkNRLGlDQUFpQztrSEFBakMsaUNBQWlDLHFMQ2xCOUMsK21CQW9CQTsyRkRGYSxpQ0FBaUM7a0JBTDdDLFNBQVM7K0JBQ0ksNkJBQTZCO3FHQWE1QixLQUFLO3NCQURmLEtBQUs7Z0JBV1UsSUFBSTtzQkFBbkIsS0FBSztnQkFFb0IsTUFBTTtzQkFBL0IsTUFBTTtnQkFDbUIsTUFBTTtzQkFBL0IsTUFBTSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7Q29tcG9uZW50LCBFdmVudEVtaXR0ZXIsIElucHV0LCBPdXRwdXR9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHtGb3JtR3JvdXB9IGZyb20gJ0Bhbmd1bGFyL2Zvcm1zJztcbmltcG9ydCB7QWN0aXZhdGVkUm91dGV9IGZyb20gJ0Bhbmd1bGFyL3JvdXRlcic7XG5pbXBvcnQge05hdHVyYWxBYnN0cmFjdENvbnRyb2xsZXJ9IGZyb20gJy4uLy4uL2NsYXNzZXMvYWJzdHJhY3QtY29udHJvbGxlcic7XG5pbXBvcnQge3Rha2VVbnRpbH0gZnJvbSAncnhqcyc7XG5cbnR5cGUgTW9kZWwgPSB7XG4gICAgaWQ/OiBzdHJpbmc7XG4gICAgcGVybWlzc2lvbnM/OiB7XG4gICAgICAgIGRlbGV0ZTogYm9vbGVhbjtcbiAgICB9O1xufTtcblxuQENvbXBvbmVudCh7XG4gICAgc2VsZWN0b3I6ICduYXR1cmFsLWZpeGVkLWJ1dHRvbi1kZXRhaWwnLFxuICAgIHRlbXBsYXRlVXJsOiAnLi9maXhlZC1idXR0b24tZGV0YWlsLmNvbXBvbmVudC5odG1sJyxcbiAgICBzdHlsZVVybHM6IFsnLi9maXhlZC1idXR0b24tZGV0YWlsLmNvbXBvbmVudC5zY3NzJ10sXG59KVxuZXhwb3J0IGNsYXNzIE5hdHVyYWxGaXhlZEJ1dHRvbkRldGFpbENvbXBvbmVudCBleHRlbmRzIE5hdHVyYWxBYnN0cmFjdENvbnRyb2xsZXIge1xuICAgIHByaXZhdGUgY2FuQ2hhbmdlID0gdHJ1ZTtcbiAgICBwdWJsaWMgaXNDcmVhdGlvbiA9IGZhbHNlO1xuXG4gICAgcHVibGljIGdldCBtb2RlbCgpOiBNb2RlbCB7XG4gICAgICAgIHJldHVybiB0aGlzLl9tb2RlbDtcbiAgICB9XG5cbiAgICBASW5wdXQoKVxuICAgIHB1YmxpYyBzZXQgbW9kZWwodmFsdWU6IE1vZGVsKSB7XG4gICAgICAgIHRoaXMuX21vZGVsID0gdmFsdWU7XG4gICAgICAgIGlmICh0aGlzLmNhbkNoYW5nZSkge1xuICAgICAgICAgICAgdGhpcy5pc0NyZWF0aW9uID0gIXRoaXMuX21vZGVsLmlkO1xuICAgICAgICAgICAgdGhpcy5jYW5DaGFuZ2UgPSBmYWxzZTtcbiAgICAgICAgfVxuICAgIH1cblxuICAgIHByaXZhdGUgX21vZGVsITogTW9kZWw7XG5cbiAgICBASW5wdXQoKSBwdWJsaWMgZm9ybSE6IEZvcm1Hcm91cDtcblxuICAgIEBPdXRwdXQoKSBwdWJsaWMgcmVhZG9ubHkgY3JlYXRlID0gbmV3IEV2ZW50RW1pdHRlcjx2b2lkPigpO1xuICAgIEBPdXRwdXQoKSBwdWJsaWMgcmVhZG9ubHkgZGVsZXRlID0gbmV3IEV2ZW50RW1pdHRlcjx2b2lkPigpO1xuXG4gICAgcHVibGljIGNvbnN0cnVjdG9yKHJvdXRlOiBBY3RpdmF0ZWRSb3V0ZSkge1xuICAgICAgICBzdXBlcigpO1xuICAgICAgICByb3V0ZS5wYXJhbXMucGlwZSh0YWtlVW50aWwodGhpcy5uZ1Vuc3Vic2NyaWJlKSkuc3Vic2NyaWJlKCgpID0+ICh0aGlzLmNhbkNoYW5nZSA9IHRydWUpKTtcbiAgICB9XG5cbiAgICBwdWJsaWMgY2xpY2tDcmVhdGUoKTogdm9pZCB7XG4gICAgICAgIGlmICh0aGlzLmZvcm0uZW5hYmxlZCkge1xuICAgICAgICAgICAgdGhpcy5jcmVhdGUuZW1pdCgpO1xuICAgICAgICB9XG4gICAgfVxuXG4gICAgcHVibGljIGNsaWNrRGVsZXRlKCk6IHZvaWQge1xuICAgICAgICBpZiAodGhpcy5mb3JtLmVuYWJsZWQpIHtcbiAgICAgICAgICAgIHRoaXMuZGVsZXRlLmVtaXQoKTtcbiAgICAgICAgfVxuICAgIH1cbn1cbiIsIjxuYXR1cmFsLWZpeGVkLWJ1dHRvblxuICAgIChjbGljayk9XCJjbGlja0NyZWF0ZSgpXCJcbiAgICAqbmdJZj1cImlzQ3JlYXRpb25cIlxuICAgIFtkaXNhYmxlZF09XCJmb3JtLmRpc2FibGVkXCJcbiAgICBbY29sb3JdPVwiZm9ybS52YWxpZCA/ICdhY2NlbnQnIDogJ3dhcm4nXCJcbiAgICBjbGFzcz1cImRldGFpbC1zcGVlZC1kaWFsXCJcbiAgICBpY29uPVwic2F2ZVwiXG4+PC9uYXR1cmFsLWZpeGVkLWJ1dHRvbj5cblxuPG5hdHVyYWwtZml4ZWQtYnV0dG9uXG4gICAgKGNsaWNrKT1cImNsaWNrRGVsZXRlKClcIlxuICAgICpuZ0lmPVwiIWlzQ3JlYXRpb24gJiYgKCFtb2RlbC5wZXJtaXNzaW9ucyB8fCBtb2RlbC5wZXJtaXNzaW9ucy5kZWxldGUpXCJcbiAgICBbZGlzYWJsZWRdPVwiZm9ybS5kaXNhYmxlZFwiXG4gICAgY2xhc3M9XCJkZXRhaWwtc3BlZWQtZGlhbFwiXG4gICAgY29sb3I9XCJ3YXJuXCJcbiAgICBpY29uPVwiZGVsZXRlX2ZvcmV2ZXJcIlxuICAgIGkxOG4tbWF0VG9vbHRpcFxuICAgIG1hdFRvb2x0aXA9XCJTdXBwcmltZXIgZMOpZmluaXRpdmVtZW50XCJcbiAgICBtYXRUb29sdGlwUG9zaXRpb249XCJsZWZ0XCJcbj48L25hdHVyYWwtZml4ZWQtYnV0dG9uPlxuIl19
|