This project is mirrored from https://*****@github.com/iqb-berlin/verona-modules-aspect.git.
Pull mirroring updated .
- Mar 02, 2022
-
-
rhenck authored
- Units and element are now built via the factory. This ensures only the wanted properties are present. All others are discarded. - Since the sanatizer is supposed to check the unit defintion version it is used by player and editor and therefore put in common. This in turn makes it necessary to put the JSON resolver settings in the root-TSConfig file. - Renamed a couple of properties to have clearer names.
-
- Feb 28, 2022
-
-
jojohoch authored
Remove manipulations from elementModel - Refactor drop list component - Use of initial values for audio and video playback time Defining the validators not in the elements anymore, but when creating the forms
-
- Feb 18, 2022
-
-
rhenck authored
- Unify font and surface props - Use intersection type for additional properties - Also rework editor props panel to properly create the combined properties recursively, passing the results to its child panel (tabs). New algorithm works without lodash, therefore the package is removed.
-
- Feb 17, 2022
-
-
rhenck authored
This removes all the classes and goes back to simple interfaces for unit, pages etc and all elements. This makes creating them easier and cleaner. Things like specific needs when setting element properties and most importantly compatibility handling is done by a special service module, that knows all the elements and how to repair old their potentially outdated definitions.
-
- Feb 09, 2022
-
-
rhenck authored
This is done according to the Angular best practices and minimizes namespace collisions when using other packages which might use the same selectors. Technically the selectors are not even becessary since we use an Angular component factory to create element components but it is still useful for the DOM element naming, for debugging purposes for example.
-
- Jan 20, 2022
-
-
rhenck authored
This way the placeholder is exactly as big as the font size. There is no space for a padding here, as the normal dropList has.
-
- Jan 12, 2022
-
-
rhenck authored
Now manages height and width by itself. So no overlay div is needed in the cloze component.
-
- Dec 06, 2021
-
-
rhenck authored
Now only sends a list with IDs as value. The actual list manipulation is done with Material helper functions (transferArrayItem...).
-
- Dec 01, 2021
- Nov 30, 2021
-
-
rhenck authored
-
- Nov 29, 2021
-
-
rhenck authored
It is meant to be used as inline positioned (sub) element. Therefore it has not postioning information and less property options than the normal drop list. Similar to the simple text field.
-
- Nov 26, 2021
-
-
rhenck authored
The problem being solved is that compound-sub-elements must not have all the properties other elements have. For exampe positioning info. Sub-Elements are positioned inline. To avoid having similar class inheritance structures for positioned and inline elements, we use interface. Positioning is done via interface and is therefore optional. Those optional properties are kept in an object in a variable. This allows to hide specifics from element classes and removes the need to initialize all the fields in every class using the interface. The elements mostly care about their own specific properties anyway. The same technique is used for font and surface elements. Here we also don't want to initialize all the styles in every class. Changing values of element properties works like before. Just set the property as if it would be a direkt prop of the element. The element itself puts the value in the currect sub-object (positioningProps, fontProps etc). For reading the values there is a similar method, but it is not used anywhere by now. Since the properties panel operates on the raw values anyway (refer CombinedProperties) and for element components this would mean calling a function in the template, which caused change detection to run the function very often and is therefore bad practice. Additional notes and refactorings: - Restructure all files in common. UIElements in the same folder etc. - Move all interfaces to the UIElement file. This avoids circular imports, which would be needed to allow PositionedElement to extend UIElement. - Interface initializers also handle reading values in the old form. - Add PositionedElement for use in canvas overlays. This is a UIElement with guaranteed postionProps. - Don't export all Material packages from common, only the ones used in player and editor. The rest is only used in common and does not need to be exported.
-
- Nov 19, 2021
-
-
rhenck authored
This allows to use them in template bindings. Used in compound elements.
-
- Nov 18, 2021
-
-
rhenck authored
- List items only have a margin between then but no longer on the outside. - Remove unused background color. This is set dynamically in the template.
-
- Nov 12, 2021
-
-
rhenck authored
This shows a outline on potential dropLists when dragging an item.
-
- Nov 10, 2021
-
-
rhenck authored
-
rhenck authored
Options and value were the same thing anyway and the value was updated once anything was changed within that dropList. The player though needs a start value and this way we have one.
-
jojohoch authored
-
rhenck authored
- Add background to dragged element via cdkDragPreview - Add placeholder box for dropping via cdkDragPlaceholder - Add animations for transitions when dragging and dropping
-
jojohoch authored
-
- Nov 09, 2021
- Nov 08, 2021
-
-
rhenck authored
Also improve conditional border style. The additional dragPreview is needed so the dragged item does not have the border.
-
rhenck authored
The width/height of 90% are a preliminary workaround to not produce overflow with the border. A better solution would be good.
-
rhenck authored
This element has a list of string as editable options. Those strings form draggable elements which may be reordered or moved between different DropList elements. Also refactor option change logic to allow any property not just the text property.
-