@kwiz/fluentui 1.0.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (110) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +1 -0
  3. package/dist/_modules/build.d.ts +2 -0
  4. package/dist/_modules/build.js +3 -0
  5. package/dist/_modules/build.js.map +1 -0
  6. package/dist/_modules/config.d.ts +1 -0
  7. package/dist/_modules/config.js +9 -0
  8. package/dist/_modules/config.js.map +1 -0
  9. package/dist/_modules/constants.d.ts +2 -0
  10. package/dist/_modules/constants.js +3 -0
  11. package/dist/_modules/constants.js.map +1 -0
  12. package/dist/_modules/exports-index.d.ts +1 -0
  13. package/dist/_modules/exports-index.js +2 -0
  14. package/dist/_modules/exports-index.js.map +1 -0
  15. package/dist/controls/button.d.ts +27 -0
  16. package/dist/controls/button.js +100 -0
  17. package/dist/controls/button.js.map +1 -0
  18. package/dist/controls/centered.d.ts +5 -0
  19. package/dist/controls/centered.js +14 -0
  20. package/dist/controls/centered.js.map +1 -0
  21. package/dist/controls/dropdown.d.ts +18 -0
  22. package/dist/controls/dropdown.js +13 -0
  23. package/dist/controls/dropdown.js.map +1 -0
  24. package/dist/controls/error-boundary.d.ts +23 -0
  25. package/dist/controls/error-boundary.js +33 -0
  26. package/dist/controls/error-boundary.js.map +1 -0
  27. package/dist/controls/exports-index.d.ts +17 -0
  28. package/dist/controls/exports-index.js +18 -0
  29. package/dist/controls/exports-index.js.map +1 -0
  30. package/dist/controls/field-editor.d.ts +13 -0
  31. package/dist/controls/field-editor.js +15 -0
  32. package/dist/controls/field-editor.js.map +1 -0
  33. package/dist/controls/file-upload.d.ts +18 -0
  34. package/dist/controls/file-upload.js +41 -0
  35. package/dist/controls/file-upload.js.map +1 -0
  36. package/dist/controls/horizontal.d.ts +8 -0
  37. package/dist/controls/horizontal.js +23 -0
  38. package/dist/controls/horizontal.js.map +1 -0
  39. package/dist/controls/input.d.ts +13 -0
  40. package/dist/controls/input.js +41 -0
  41. package/dist/controls/input.js.map +1 -0
  42. package/dist/controls/list.d.ts +21 -0
  43. package/dist/controls/list.js +72 -0
  44. package/dist/controls/list.js.map +1 -0
  45. package/dist/controls/loading.d.ts +5 -0
  46. package/dist/controls/loading.js +7 -0
  47. package/dist/controls/loading.js.map +1 -0
  48. package/dist/controls/please-wait.d.ts +17 -0
  49. package/dist/controls/please-wait.js +16 -0
  50. package/dist/controls/please-wait.js.map +1 -0
  51. package/dist/controls/prompt.d.ts +16 -0
  52. package/dist/controls/prompt.js +21 -0
  53. package/dist/controls/prompt.js.map +1 -0
  54. package/dist/controls/search.d.ts +13 -0
  55. package/dist/controls/search.js +47 -0
  56. package/dist/controls/search.js.map +1 -0
  57. package/dist/controls/section.d.ts +14 -0
  58. package/dist/controls/section.js +27 -0
  59. package/dist/controls/section.js.map +1 -0
  60. package/dist/controls/svg.d.ts +23 -0
  61. package/dist/controls/svg.js +45 -0
  62. package/dist/controls/svg.js.map +1 -0
  63. package/dist/controls/vertical-content.d.ts +6 -0
  64. package/dist/controls/vertical-content.js +37 -0
  65. package/dist/controls/vertical-content.js.map +1 -0
  66. package/dist/controls/vertical.d.ts +8 -0
  67. package/dist/controls/vertical.js +23 -0
  68. package/dist/controls/vertical.js.map +1 -0
  69. package/dist/exports-index.d.ts +3 -0
  70. package/dist/exports-index.js +4 -0
  71. package/dist/exports-index.js.map +1 -0
  72. package/dist/helpers/hooks.d.ts +22 -0
  73. package/dist/helpers/hooks.js +173 -0
  74. package/dist/helpers/hooks.js.map +1 -0
  75. package/dist/index.d.ts +19 -0
  76. package/dist/index.js +20 -0
  77. package/dist/index.js.map +1 -0
  78. package/dist/styles/exports-index.d.ts +2 -0
  79. package/dist/styles/exports-index.js +3 -0
  80. package/dist/styles/exports-index.js.map +1 -0
  81. package/dist/styles/styles.d.ts +19 -0
  82. package/dist/styles/styles.js +79 -0
  83. package/dist/styles/styles.js.map +1 -0
  84. package/dist/styles/theme.d.ts +6 -0
  85. package/dist/styles/theme.js +77 -0
  86. package/dist/styles/theme.js.map +1 -0
  87. package/package.json +71 -0
  88. package/src/_modules/config.ts +9 -0
  89. package/src/_modules/constants.ts +3 -0
  90. package/src/controls/button.tsx +154 -0
  91. package/src/controls/centered.tsx +23 -0
  92. package/src/controls/dropdown.tsx +28 -0
  93. package/src/controls/error-boundary.tsx +42 -0
  94. package/src/controls/field-editor.tsx +42 -0
  95. package/src/controls/file-upload.tsx +68 -0
  96. package/src/controls/horizontal.tsx +35 -0
  97. package/src/controls/input.tsx +59 -0
  98. package/src/controls/list.tsx +118 -0
  99. package/src/controls/loading.tsx +11 -0
  100. package/src/controls/please-wait.tsx +32 -0
  101. package/src/controls/prompt.tsx +59 -0
  102. package/src/controls/search.tsx +66 -0
  103. package/src/controls/section.tsx +52 -0
  104. package/src/controls/svg.tsx +120 -0
  105. package/src/controls/vertical-content.tsx +50 -0
  106. package/src/controls/vertical.tsx +35 -0
  107. package/src/helpers/hooks.ts +189 -0
  108. package/src/index.ts +19 -0
  109. package/src/styles/styles.ts +87 -0
  110. package/src/styles/theme.ts +91 -0
@@ -0,0 +1,173 @@
1
+ import { isDebug, isFunction, isNotEmptyArray, isNullOrEmptyString, jsonStringify, LoggerLevel, objectsEqual, wrapFunction } from "@kwiz/common";
2
+ import { useCallback, useEffect, useRef, useState } from "react";
3
+ import { GetLogger } from "../_modules/config";
4
+ import { KnownClassNames } from "../styles/styles";
5
+ const logger = GetLogger("helpers/hooks");
6
+ /** Empty array ensures that effect is only run on mount */
7
+ export const useEffectOnlyOnMount = [];
8
+ /** set state on steroids. provide promise callback after render, onChange transformer and automatic skip-set when value not changed */
9
+ export function useStateEX(initialValue, options) {
10
+ options = options || {};
11
+ const name = options.name || '';
12
+ let logger = GetLogger(`useStateWithTrack${isNullOrEmptyString(name) ? '' : ` ${name}`}`);
13
+ logger.setLevel(LoggerLevel.WARN);
14
+ const [value, setValueInState] = useState(initialValue);
15
+ const currentValue = useRef(value);
16
+ /** make this a collection in case several callers are awaiting the same propr update */
17
+ const resolveState = useRef([]);
18
+ const isMounted = useRef(false);
19
+ useEffect(() => {
20
+ isMounted.current = true;
21
+ return () => {
22
+ isMounted.current = false;
23
+ };
24
+ }, useEffectOnlyOnMount);
25
+ function resolvePromises() {
26
+ if (isNotEmptyArray(resolveState.current)) {
27
+ let resolvers = resolveState.current.slice();
28
+ resolveState.current = []; //clear
29
+ resolvers.map(r => r(currentValue.current));
30
+ }
31
+ }
32
+ ;
33
+ useEffect(() => {
34
+ resolvePromises();
35
+ if (isNotEmptyArray(resolveState.current)) {
36
+ logger.log(`resolved after render`);
37
+ let resolvers = resolveState.current.slice();
38
+ resolveState.current = []; //clear
39
+ resolvers.map(r => r(value));
40
+ }
41
+ }, [value, resolveState.current]);
42
+ let setValueWithCheck = !options.skipUpdateIfSame ? setValueInState : (newValue) => {
43
+ logger.groupSync('conditional value change', log => {
44
+ if (logger.getLevel() === LoggerLevel.VERBOSE) {
45
+ log('old: ' + jsonStringify(currentValue.current));
46
+ log('new: ' + jsonStringify(newValue));
47
+ }
48
+ if (!objectsEqual(newValue, currentValue.current)) {
49
+ log(`value changed`);
50
+ setValueInState(newValue);
51
+ }
52
+ else {
53
+ log(`value unchanged`);
54
+ resolvePromises();
55
+ }
56
+ });
57
+ };
58
+ let setValueWithEvents = wrapFunction(setValueWithCheck, {
59
+ before: newValue => isFunction(options.onChange) ? options.onChange(newValue) : newValue,
60
+ after: newValue => currentValue.current = newValue
61
+ });
62
+ const setValue = useCallback((newState) => new Promise(resolve => {
63
+ if (!isMounted.current) {
64
+ //unmounted may never resolve
65
+ logger.log(`resolved without wait`);
66
+ resolve(newState);
67
+ }
68
+ else {
69
+ resolveState.current.push(resolve);
70
+ setValueWithEvents(newState);
71
+ }
72
+ }), []);
73
+ return [value, setValue, currentValue];
74
+ }
75
+ export function useTrackFocus(props) {
76
+ const wrapperDiv = useRef(null);
77
+ useEffect(() => {
78
+ function focusIn(e) {
79
+ let elm = e.target; //document.activeElement;
80
+ if (wrapperDiv.current) {
81
+ while (elm && elm !== wrapperDiv.current) {
82
+ elm = elm.parentElement;
83
+ }
84
+ }
85
+ else
86
+ elm = null;
87
+ if (wrapperDiv.current && elm === wrapperDiv.current)
88
+ props.onFocus();
89
+ else
90
+ props.onLoseFocus();
91
+ }
92
+ if (wrapperDiv.current) {
93
+ if (wrapperDiv.current)
94
+ wrapperDiv.current.tabIndex = 1;
95
+ window.addEventListener("focusin", focusIn);
96
+ // Remove event listener on cleanup
97
+ return () => window.removeEventListener("focusin", focusIn);
98
+ }
99
+ }, [wrapperDiv.current]);
100
+ return wrapperDiv;
101
+ }
102
+ export function useWindowSize() {
103
+ // Initialize state with undefined width/height so server and client renders match
104
+ // Learn more here: https://joshwcomeau.com/react/the-perils-of-rehydration/
105
+ const [windowSize, setWindowSize] = useState({
106
+ width: undefined,
107
+ height: undefined
108
+ });
109
+ useEffect(() => {
110
+ // Handler to call on window resize
111
+ function handleResize() {
112
+ // Set window width/height to state
113
+ setWindowSize({
114
+ width: window.innerWidth,
115
+ height: window.innerHeight
116
+ });
117
+ }
118
+ // Add event listener
119
+ window.addEventListener("resize", handleResize);
120
+ // Call handler right away so state gets updated with initial window size
121
+ handleResize();
122
+ // Remove event listener on cleanup
123
+ return () => window.removeEventListener("resize", handleResize);
124
+ }, useEffectOnlyOnMount);
125
+ return windowSize;
126
+ }
127
+ export function useIsInPrint() {
128
+ // Initialize state with false
129
+ const [printMode, setPrintMode] = useState(false);
130
+ useEffect(() => {
131
+ function forcePrint(e) {
132
+ if (e.ctrlKey && e.shiftKey && e.altKey) {
133
+ if (e.key.toLocaleLowerCase() === "q") {
134
+ document.body.classList.remove(KnownClassNames.print);
135
+ handlePrint(e, false);
136
+ }
137
+ else {
138
+ console.warn('forced print mode - to exit refresh to ctrl+shift+alt+q');
139
+ document.body.classList.add(KnownClassNames.print);
140
+ handlePrint(e, true);
141
+ }
142
+ }
143
+ }
144
+ // Handler to call on printing
145
+ function handlePrint(e, force) {
146
+ if (force === true)
147
+ setPrintMode(true);
148
+ else if (window.matchMedia) {
149
+ var mediaQueryList = window.matchMedia('print');
150
+ if (mediaQueryList.matches) {
151
+ setPrintMode(true);
152
+ }
153
+ else {
154
+ setPrintMode(false);
155
+ }
156
+ }
157
+ }
158
+ // Add event listener
159
+ window.addEventListener("print", handlePrint);
160
+ if (isDebug())
161
+ window.addEventListener("keydown", forcePrint);
162
+ // Call handler right away so state gets updated with initial printing state
163
+ handlePrint();
164
+ // Remove event listener on cleanup
165
+ return () => {
166
+ window.removeEventListener("print", handlePrint);
167
+ if (isDebug())
168
+ window.removeEventListener("keydown", forcePrint);
169
+ };
170
+ }, useEffectOnlyOnMount);
171
+ return printMode;
172
+ }
173
+ //# sourceMappingURL=hooks.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"hooks.js","sourceRoot":"","sources":["../../src/helpers/hooks.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,19 @@
1
+ export * from './controls/button';
2
+ export * from './controls/centered';
3
+ export * from './controls/dropdown';
4
+ export * from './controls/error-boundary';
5
+ export * from './controls/field-editor';
6
+ export * from './controls/file-upload';
7
+ export * from './controls/horizontal';
8
+ export * from './controls/input';
9
+ export * from './controls/list';
10
+ export * from './controls/loading';
11
+ export * from './controls/please-wait';
12
+ export * from './controls/prompt';
13
+ export * from './controls/search';
14
+ export * from './controls/section';
15
+ export * from './controls/svg';
16
+ export * from './controls/vertical';
17
+ export * from './controls/vertical-content';
18
+ export * from './helpers/hooks';
19
+ export { KnownClassNames } from './styles/styles';
package/dist/index.js ADDED
@@ -0,0 +1,20 @@
1
+ export * from './controls/button';
2
+ export * from './controls/centered';
3
+ export * from './controls/dropdown';
4
+ export * from './controls/error-boundary';
5
+ export * from './controls/field-editor';
6
+ export * from './controls/file-upload';
7
+ export * from './controls/horizontal';
8
+ export * from './controls/input';
9
+ export * from './controls/list';
10
+ export * from './controls/loading';
11
+ export * from './controls/please-wait';
12
+ export * from './controls/prompt';
13
+ export * from './controls/search';
14
+ export * from './controls/section';
15
+ export * from './controls/svg';
16
+ export * from './controls/vertical';
17
+ export * from './controls/vertical-content';
18
+ export * from './helpers/hooks';
19
+ export { KnownClassNames } from './styles/styles';
20
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,mBAAmB,CAAC;AAClC,cAAc,qBAAqB,CAAC;AACpC,cAAc,qBAAqB,CAAC;AACpC,cAAc,2BAA2B,CAAC;AAC1C,cAAc,yBAAyB,CAAC;AACxC,cAAc,wBAAwB,CAAC;AACvC,cAAc,uBAAuB,CAAC;AACtC,cAAc,kBAAkB,CAAC;AACjC,cAAc,iBAAiB,CAAC;AAChC,cAAc,oBAAoB,CAAC;AACnC,cAAc,wBAAwB,CAAC;AACvC,cAAc,mBAAmB,CAAC;AAClC,cAAc,mBAAmB,CAAC;AAClC,cAAc,oBAAoB,CAAC;AACnC,cAAc,gBAAgB,CAAC;AAC/B,cAAc,qBAAqB,CAAC;AACpC,cAAc,6BAA6B,CAAC;AAC5C,cAAc,iBAAiB,CAAC;AAChC,OAAO,EAAE,eAAe,EAAE,MAAM,iBAAiB,CAAC"}
@@ -0,0 +1,2 @@
1
+ export * from './styles';
2
+ export * from './theme';
@@ -0,0 +1,3 @@
1
+ export * from './styles';
2
+ export * from './theme';
3
+ //# sourceMappingURL=exports-index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"exports-index.js","sourceRoot":"","sources":["../../src/styles/exports-index.ts"],"names":[],"mappings":"AAAA,cAAc,UAAU,CAAC;AACzB,cAAc,SAAS,CAAC"}
@@ -0,0 +1,19 @@
1
+ import { GriffelStyle } from "@fluentui/react-components";
2
+ export declare namespace mixins {
3
+ const main: GriffelStyle;
4
+ const clickable: GriffelStyle;
5
+ const float: GriffelStyle;
6
+ const flex: GriffelStyle;
7
+ const wrap: GriffelStyle;
8
+ const nogap: GriffelStyle;
9
+ const ellipsis: GriffelStyle;
10
+ }
11
+ export declare const KnownClassNames: {
12
+ print: string;
13
+ section: string;
14
+ vertical: string;
15
+ horizontal: string;
16
+ list: string;
17
+ };
18
+ export declare const useCommonStyles: () => Record<"printShow" | "printHide", string>;
19
+ export declare const widthMedium = 360;
@@ -0,0 +1,79 @@
1
+ import { makeStyles, tokens } from "@fluentui/react-components";
2
+ export var mixins;
3
+ (function (mixins) {
4
+ mixins.main = {
5
+ flexShrink: 1,
6
+ flexGrow: 1
7
+ };
8
+ mixins.clickable = {
9
+ cursor: "pointer",
10
+ ['& label']: {
11
+ cursor: "pointer"
12
+ }
13
+ };
14
+ const box = {
15
+ padding: tokens.spacingHorizontalM,
16
+ borderRadius: tokens.borderRadiusMedium,
17
+ boxShadow: tokens.shadow4,
18
+ margin: tokens.spacingHorizontalXXS
19
+ };
20
+ mixins.float = Object.assign(Object.assign({}, box), {
21
+ /** make buttons work */
22
+ position: "relative",
23
+ /** make buttons work */
24
+ maxWidth: "33%",
25
+ /** stop bleeding into page */
26
+ overflowX: "hidden", ['& img']: {
27
+ maxWidth: "100%"
28
+ } });
29
+ mixins.flex = {
30
+ display: 'flex',
31
+ flexWrap: 'nowrap',
32
+ rowGap: tokens.spacingVerticalM,
33
+ columnGap: tokens.spacingVerticalM,
34
+ };
35
+ mixins.wrap = {
36
+ flexWrap: "wrap"
37
+ };
38
+ mixins.nogap = {
39
+ rowGap: 0,
40
+ columnGap: 0
41
+ };
42
+ mixins.ellipsis = {
43
+ whiteSpace: 'nowrap',
44
+ display: 'block',
45
+ overflow: 'hidden',
46
+ textOverflow: 'ellipsis'
47
+ };
48
+ // export const box: GriffelStyle = {
49
+ // }
50
+ })(mixins || (mixins = {}));
51
+ export const KnownClassNames = {
52
+ print: 'print-root',
53
+ section: 'kfui-section',
54
+ vertical: 'kfui-vertical',
55
+ horizontal: 'kfui-horizontal',
56
+ list: 'kfui-list'
57
+ };
58
+ export const useCommonStyles = makeStyles({
59
+ printShow: {
60
+ display: 'none',
61
+ [`:global(body.${KnownClassNames.print})`]: {
62
+ display: 'unset',
63
+ },
64
+ '@media print': {
65
+ display: 'unset',
66
+ }
67
+ },
68
+ printHide: {
69
+ [`:global(body.${KnownClassNames.print})`]: {
70
+ display: 'none !important'
71
+ },
72
+ '@media print': {
73
+ display: 'none !important'
74
+ }
75
+ },
76
+ });
77
+ export const widthMedium = 360;
78
+ //export const widthWide = 520;
79
+ //# sourceMappingURL=styles.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"styles.js","sourceRoot":"","sources":["../../src/styles/styles.ts"],"names":[],"mappings":"AAAA,OAAO,EAAgB,UAAU,EAAE,MAAM,EAAE,MAAM,4BAA4B,CAAC;AAE9E,MAAM,KAAQ,MAAM,CAsDnB;AAtDD,WAAc,MAAM;IACH,WAAI,GAAiB;QAC9B,UAAU,EAAE,CAAC;QACb,QAAQ,EAAE,CAAC;KACd,CAAC;IACW,gBAAS,GAAiB;QACnC,MAAM,EAAE,SAAS;QACjB,CAAC,SAAS,CAAC,EAAE;YACT,MAAM,EAAE,SAAS;SACpB;KACJ,CAAA;IACD,MAAM,GAAG,GAAiB;QACtB,OAAO,EAAE,MAAM,CAAC,kBAAkB;QAClC,YAAY,EAAE,MAAM,CAAC,kBAAkB;QACvC,SAAS,EAAE,MAAM,CAAC,OAAO;QACzB,MAAM,EAAE,MAAM,CAAC,oBAAoB;KACtC,CAAA;IACY,YAAK,mCACX,GAAG;QACN,wBAAwB;QACxB,QAAQ,EAAE,UAAU;QACpB,wBAAwB;QACxB,QAAQ,EAAE,KAAK;QACf,8BAA8B;QAC9B,SAAS,EAAE,QAAQ,EAEnB,CAAC,OAAO,CAAC,EAAE;YACP,QAAQ,EAAE,MAAM;SACnB,GACJ,CAAA;IAEY,WAAI,GAAiB;QAC9B,OAAO,EAAE,MAAM;QACf,QAAQ,EAAE,QAAQ;QAClB,MAAM,EAAE,MAAM,CAAC,gBAAgB;QAC/B,SAAS,EAAE,MAAM,CAAC,gBAAgB;KACrC,CAAA;IAEY,WAAI,GAAiB;QAC9B,QAAQ,EAAE,MAAM;KACnB,CAAA;IACY,YAAK,GAAiB;QAC/B,MAAM,EAAE,CAAC;QACT,SAAS,EAAE,CAAC;KACf,CAAA;IACY,eAAQ,GAAiB;QAClC,UAAU,EAAE,QAAQ;QACpB,OAAO,EAAE,OAAO;QAChB,QAAQ,EAAE,QAAQ;QAClB,YAAY,EAAE,UAAU;KAC3B,CAAA;IAED,qCAAqC;IACrC,IAAI;AACR,CAAC,EAtDa,MAAM,KAAN,MAAM,QAsDnB;AAED,MAAM,CAAC,MAAM,eAAe,GAAG;IAC3B,KAAK,EAAE,YAAY;IACnB,OAAO,EAAE,cAAc;IACvB,QAAQ,EAAE,eAAe;IACzB,UAAU,EAAE,iBAAiB;IAC7B,IAAI,EAAE,WAAW;CACpB,CAAA;AACD,MAAM,CAAC,MAAM,eAAe,GAAG,UAAU,CAAC;IACtC,SAAS,EAAE;QACP,OAAO,EAAE,MAAM;QACf,CAAC,gBAAgB,eAAe,CAAC,KAAK,GAAG,CAAC,EAAE;YACxC,OAAO,EAAE,OAAO;SACnB;QACD,cAAc,EAAE;YACZ,OAAO,EAAE,OAAO;SACnB;KACJ;IACD,SAAS,EAAE;QACP,CAAC,gBAAgB,eAAe,CAAC,KAAK,GAAG,CAAC,EAAE;YACxC,OAAO,EAAE,iBAAiB;SAC7B;QACD,cAAc,EAAE;YACZ,OAAO,EAAE,iBAAiB;SAC7B;KACJ;CACJ,CAAC,CAAA;AAEF,MAAM,CAAC,MAAM,WAAW,GAAG,GAAG,CAAC;AAC/B,+BAA+B"}
@@ -0,0 +1,6 @@
1
+ import { BrandVariants, Theme } from "@fluentui/react-components";
2
+ export interface iThemeContext {
3
+ teams?: boolean;
4
+ dark?: boolean;
5
+ }
6
+ export declare function getTheme(ctx: iThemeContext, t?: BrandVariants): Theme;
@@ -0,0 +1,77 @@
1
+ import { createDarkTheme, createLightTheme, teamsDarkTheme, teamsLightTheme } from "@fluentui/react-components";
2
+ export function getTheme(ctx, t = kThemeDefault) {
3
+ return ctx.dark
4
+ ? getDarkTheme(ctx, t)
5
+ : getLightTheme(ctx, t);
6
+ }
7
+ const kThemeDefault = {
8
+ 10: "#04010A",
9
+ 20: "#16103B",
10
+ 30: "#17176F",
11
+ 40: "#0F1D9A",
12
+ 50: "#2F2AA1",
13
+ 60: "#4338A8",
14
+ 70: "#5546AF",
15
+ 80: "#6555B6",
16
+ 90: "#7563BD",
17
+ 100: "#8472C4",
18
+ 110: "#9282CB",
19
+ 120: "#A191D2",
20
+ 130: "#AFA1D9",
21
+ 140: "#BDB1E0",
22
+ 150: "#CBC1E7",
23
+ 160: "#D9D2EE"
24
+ };
25
+ const kThemeOrange = {
26
+ 10: "#040301",
27
+ 20: "#1E170A",
28
+ 30: "#312610",
29
+ 40: "#403112",
30
+ 50: "#503D14",
31
+ 60: "#604915",
32
+ 70: "#705516",
33
+ 80: "#816216",
34
+ 90: "#926E16",
35
+ 100: "#A37B15",
36
+ 110: "#B58914",
37
+ 120: "#C79612",
38
+ 130: "#DAA40E",
39
+ 140: "#EDB208",
40
+ 150: "#FFC001",
41
+ 160: "#FFD47F"
42
+ };
43
+ const kThemeSecondary = {
44
+ 10: "#020304",
45
+ 20: "#101A1D",
46
+ 30: "#162B32",
47
+ 40: "#1A3742",
48
+ 50: "#1D4552",
49
+ 60: "#1F5363",
50
+ 70: "#216175",
51
+ 80: "#227087",
52
+ 90: "#227F9A",
53
+ 100: "#208EAD",
54
+ 110: "#1E9EC0",
55
+ 120: "#1AADD4",
56
+ 130: "#12BEE8",
57
+ 140: "#02CEFD",
58
+ 150: "#6BDAFF",
59
+ 160: "#A0E5FF"
60
+ };
61
+ function getLightTheme(ctx, t = kThemeDefault) {
62
+ if (ctx.teams)
63
+ return teamsLightTheme;
64
+ //return jsonClone(webLightTheme);
65
+ const lightTheme = Object.assign({}, createLightTheme(t));
66
+ return lightTheme;
67
+ }
68
+ function getDarkTheme(ctx, t = kThemeDefault) {
69
+ if (ctx.teams)
70
+ return teamsDarkTheme;
71
+ //return jsonClone(webDarkTheme);
72
+ const darkTheme = Object.assign({}, createDarkTheme(t));
73
+ darkTheme.colorBrandForeground1 = t[110];
74
+ darkTheme.colorBrandForeground2 = t[120];
75
+ return darkTheme;
76
+ }
77
+ //# sourceMappingURL=theme.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"theme.js","sourceRoot":"","sources":["../../src/styles/theme.ts"],"names":[],"mappings":"AAAA,OAAO,EAAwB,eAAe,EAAE,gBAAgB,EAAE,cAAc,EAAE,eAAe,EAAE,MAAM,4BAA4B,CAAC;AAOtI,MAAM,UAAU,QAAQ,CAAC,GAAkB,EAAE,IAAmB,aAAa;IACzE,OAAO,GAAG,CAAC,IAAI;QACX,CAAC,CAAC,YAAY,CAAC,GAAG,EAAE,CAAC,CAAC;QACtB,CAAC,CAAC,aAAa,CAAC,GAAG,EAAE,CAAC,CAAC,CAAC;AAChC,CAAC;AAGD,MAAM,aAAa,GAAkB;IACjC,EAAE,EAAE,SAAS;IACb,EAAE,EAAE,SAAS;IACb,EAAE,EAAE,SAAS;IACb,EAAE,EAAE,SAAS;IACb,EAAE,EAAE,SAAS;IACb,EAAE,EAAE,SAAS;IACb,EAAE,EAAE,SAAS;IACb,EAAE,EAAE,SAAS;IACb,EAAE,EAAE,SAAS;IACb,GAAG,EAAE,SAAS;IACd,GAAG,EAAE,SAAS;IACd,GAAG,EAAE,SAAS;IACd,GAAG,EAAE,SAAS;IACd,GAAG,EAAE,SAAS;IACd,GAAG,EAAE,SAAS;IACd,GAAG,EAAE,SAAS;CACjB,CAAC;AAEF,MAAM,YAAY,GAAkB;IAChC,EAAE,EAAE,SAAS;IACb,EAAE,EAAE,SAAS;IACb,EAAE,EAAE,SAAS;IACb,EAAE,EAAE,SAAS;IACb,EAAE,EAAE,SAAS;IACb,EAAE,EAAE,SAAS;IACb,EAAE,EAAE,SAAS;IACb,EAAE,EAAE,SAAS;IACb,EAAE,EAAE,SAAS;IACb,GAAG,EAAE,SAAS;IACd,GAAG,EAAE,SAAS;IACd,GAAG,EAAE,SAAS;IACd,GAAG,EAAE,SAAS;IACd,GAAG,EAAE,SAAS;IACd,GAAG,EAAE,SAAS;IACd,GAAG,EAAE,SAAS;CACjB,CAAC;AAEF,MAAM,eAAe,GAAkB;IACnC,EAAE,EAAE,SAAS;IACb,EAAE,EAAE,SAAS;IACb,EAAE,EAAE,SAAS;IACb,EAAE,EAAE,SAAS;IACb,EAAE,EAAE,SAAS;IACb,EAAE,EAAE,SAAS;IACb,EAAE,EAAE,SAAS;IACb,EAAE,EAAE,SAAS;IACb,EAAE,EAAE,SAAS;IACb,GAAG,EAAE,SAAS;IACd,GAAG,EAAE,SAAS;IACd,GAAG,EAAE,SAAS;IACd,GAAG,EAAE,SAAS;IACd,GAAG,EAAE,SAAS;IACd,GAAG,EAAE,SAAS;IACd,GAAG,EAAE,SAAS;CACjB,CAAC;AAEF,SAAS,aAAa,CAAC,GAAkB,EAAE,IAAmB,aAAa;IACvE,IAAI,GAAG,CAAC,KAAK;QAAE,OAAO,eAAe,CAAC;IACtC,kCAAkC;IAClC,MAAM,UAAU,qBACT,gBAAgB,CAAC,CAAC,CAAC,CACzB,CAAC;IACF,OAAO,UAAU,CAAC;AACtB,CAAC;AAED,SAAS,YAAY,CAAC,GAAkB,EAAE,IAAmB,aAAa;IACtE,IAAI,GAAG,CAAC,KAAK;QAAE,OAAO,cAAc,CAAC;IACrC,iCAAiC;IACjC,MAAM,SAAS,qBACR,eAAe,CAAC,CAAC,CAAC,CACxB,CAAC;IAEF,SAAS,CAAC,qBAAqB,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC;IACzC,SAAS,CAAC,qBAAqB,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC;IACzC,OAAO,SAAS,CAAC;AACrB,CAAC"}
package/package.json ADDED
@@ -0,0 +1,71 @@
1
+ {
2
+ "name": "@kwiz/fluentui",
3
+ "version": "1.0.00",
4
+ "description": "KWIZ common controls for FluentUI",
5
+ "module": "dist/index.js",
6
+ "types": "dist/index.d.ts",
7
+ "exports": {
8
+ ".": {
9
+ "types": "./dist/index.d.ts",
10
+ "import": "./dist/index.js",
11
+ "default": "./dist/index.js"
12
+ },
13
+ "./package.json": "./package.json"
14
+ },
15
+ "scripts": {
16
+ "watch": "tsc -watch",
17
+ "build": "npm run test && tsc",
18
+ "build-explain": "tsc --explainFiles",
19
+ "check-dependencies": "madge --circular ./src",
20
+ "create-link": "npm link",
21
+ "test": "node --import tsx --test src",
22
+ "link-local-kwiz": "npm link @kwiz/common",
23
+ "__update-kwiz-packages": "npm install @kwiz/common@latest",
24
+ "npm-v-patch": "npm version patch",
25
+ "npm-v-major": "npm version major",
26
+ "npm-publish": "npm publish --access public",
27
+ "reset-repo": "git fetch origin && git reset --hard origin/main"
28
+ },
29
+ "repository": {
30
+ "type": "git",
31
+ "url": "git+https://github.com/KWizCom/fluentui.git"
32
+ },
33
+ "keywords": [
34
+ "KWIZ",
35
+ "FluentUI"
36
+ ],
37
+ "author": "Shai Petel",
38
+ "contributors": [
39
+ "Shai Petel"
40
+ ],
41
+ "license": "MIT",
42
+ "bugs": {
43
+ "url": "https://github.com/KWizCom/fluentui/issues",
44
+ "email": "support@kwizcom.com"
45
+ },
46
+ "homepage": "https://github.com/KWizCom/fluentui#readme",
47
+ "private": false,
48
+ "engines": {
49
+ "node": ">=16"
50
+ },
51
+ "packageManager": "npm@9.5.1",
52
+ "devDependencies": {
53
+ "fs-extra": "^11.2.0",
54
+ "madge": "^6.1.0",
55
+ "tsx": "^4.7.1",
56
+ "typescript": "^5.3.3"
57
+ },
58
+ "dependencies": {
59
+ "@kwiz/common": "^1.0.58",
60
+ "esbuild": "^0.19.12",
61
+ "get-tsconfig": "^4.7.2",
62
+ "resolve-pkg-maps": "^1.0.0"
63
+ },
64
+ "peerDependencies": {
65
+ "@fluentui/react-components": ">=9.54.17 <10.0.0",
66
+ "@types/react": ">=16.14.0 <19.0.0",
67
+ "@types/react-dom": ">=16.9.0 <19.0.0",
68
+ "react": ">=16.14.0 <19.0.0",
69
+ "react-dom": ">=16.14.0 <19.0.0"
70
+ }
71
+ }
@@ -0,0 +1,9 @@
1
+ import { config } from "@kwiz/common";
2
+ import { BuildNumber, ReleaseStatus } from "./constants";
3
+
4
+ export const { logger: GetLogger } = config({
5
+ BuildNumber: BuildNumber,
6
+ IsLocalDev: false,
7
+ ReleaseStatus: ReleaseStatus,
8
+ ProjectName: "[fluentui]"
9
+ });
@@ -0,0 +1,3 @@
1
+
2
+ export var BuildNumber = 'unset';
3
+ export const ReleaseStatus = "npm";