feat:add CollectionDemo
This commit is contained in:
parent
f0de868a34
commit
f2b4ba23c4
@ -13,4 +13,5 @@ export default [
|
|||||||
'src/NavigatorDemo',
|
'src/NavigatorDemo',
|
||||||
'src/NavbarDemo',
|
'src/NavbarDemo',
|
||||||
'src/RefreshableDemo',
|
'src/RefreshableDemo',
|
||||||
|
'src/CollectionDemo',
|
||||||
]
|
]
|
@ -15,9 +15,9 @@ export default bundles.map(bundle => {
|
|||||||
commonjs()
|
commonjs()
|
||||||
],
|
],
|
||||||
external: ['reflect-metadata', 'doric'],
|
external: ['reflect-metadata', 'doric'],
|
||||||
onwarn: function(warning) {
|
onwarn: function (warning) {
|
||||||
if ( warning.code === 'THIS_IS_UNDEFINED' ) { return; }
|
if (warning.code === 'THIS_IS_UNDEFINED') { return; }
|
||||||
console.warn( warning.message );
|
console.warn(warning.message);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
})
|
})
|
31
demo/src/CollectionDemo.ts
Normal file
31
demo/src/CollectionDemo.ts
Normal file
@ -0,0 +1,31 @@
|
|||||||
|
import { Group, Panel, collection, layoutConfig, CollectionItem, } from "doric";
|
||||||
|
import { colors, label } from "./utils";
|
||||||
|
|
||||||
|
const imageUrls = [
|
||||||
|
'http://b.hiphotos.baidu.com/image/pic/item/908fa0ec08fa513db777cf78376d55fbb3fbd9b3.jpg',
|
||||||
|
'http://f.hiphotos.baidu.com/image/pic/item/0e2442a7d933c8956c0e8eeadb1373f08202002a.jpg',
|
||||||
|
'http://f.hiphotos.baidu.com/image/pic/item/b151f8198618367aa7f3cc7424738bd4b31ce525.jpg',
|
||||||
|
'http://b.hiphotos.baidu.com/image/pic/item/0eb30f2442a7d9337119f7dba74bd11372f001e0.jpg',
|
||||||
|
'http://a.hiphotos.baidu.com/image/h%3D300/sign=b38f3fc35b0fd9f9bf175369152cd42b/9a504fc2d5628535bdaac29e9aef76c6a6ef63c2.jpg',
|
||||||
|
'http://h.hiphotos.baidu.com/image/pic/item/810a19d8bc3eb1354c94a704ac1ea8d3fd1f4439.jpg',
|
||||||
|
'http://calonye.com/wp-content/uploads/2015/08/0-wx_fmtgiftpwebpwxfrom5wx_lazy1-9.gif',
|
||||||
|
'http://hbimg.b0.upaiyun.com/ca29ea125b7f2d580f573e48eb594b1ef509757f34a08-m0hK45_fw658',
|
||||||
|
'https://misc.aotu.io/ONE-SUNDAY/SteamEngine.png',
|
||||||
|
]
|
||||||
|
@Entry
|
||||||
|
class CollectionDemo extends Panel {
|
||||||
|
build(rootView: Group): void {
|
||||||
|
collection({
|
||||||
|
layoutConfig: layoutConfig().atmost(),
|
||||||
|
itemCount: 50,
|
||||||
|
renderItem: (idx) => {
|
||||||
|
return new CollectionItem().apply({
|
||||||
|
bgColor: colors[idx % colors.length],
|
||||||
|
width: 70 + idx,
|
||||||
|
height: 70 + idx,
|
||||||
|
})
|
||||||
|
},
|
||||||
|
})
|
||||||
|
.in(rootView)
|
||||||
|
}
|
||||||
|
}
|
@ -40,6 +40,7 @@ - (void)layoutSelf:(CGSize)targetSize {
|
|||||||
|
|
||||||
@interface DoricCollectionNode () <UICollectionViewDataSource, UICollectionViewDelegateFlowLayout>
|
@interface DoricCollectionNode () <UICollectionViewDataSource, UICollectionViewDelegateFlowLayout>
|
||||||
@property(nonatomic, strong) NSMutableDictionary <NSNumber *, NSString *> *itemViewIds;
|
@property(nonatomic, strong) NSMutableDictionary <NSNumber *, NSString *> *itemViewIds;
|
||||||
|
@property(nonatomic, strong) NSMutableDictionary <NSNumber *, NSValue *> *itemSizeInfo;
|
||||||
@property(nonatomic, assign) NSUInteger itemCount;
|
@property(nonatomic, assign) NSUInteger itemCount;
|
||||||
@property(nonatomic, assign) NSUInteger batchCount;
|
@property(nonatomic, assign) NSUInteger batchCount;
|
||||||
@end
|
@end
|
||||||
@ -55,7 +56,7 @@ - (instancetype)initWithContext:(DoricContext *)doricContext {
|
|||||||
|
|
||||||
- (UICollectionView *)build {
|
- (UICollectionView *)build {
|
||||||
UICollectionViewFlowLayout *flowLayout = [[UICollectionViewFlowLayout alloc] init];
|
UICollectionViewFlowLayout *flowLayout = [[UICollectionViewFlowLayout alloc] init];
|
||||||
[flowLayout setScrollDirection:UICollectionViewScrollDirectionHorizontal];
|
[flowLayout setScrollDirection:UICollectionViewScrollDirectionVertical];
|
||||||
|
|
||||||
return [[[DoricCollectionView alloc] initWithFrame:CGRectZero
|
return [[[DoricCollectionView alloc] initWithFrame:CGRectZero
|
||||||
collectionViewLayout:flowLayout]
|
collectionViewLayout:flowLayout]
|
||||||
@ -72,7 +73,7 @@ - (void)blendView:(UICollectionView *)view forPropName:(NSString *)name propValu
|
|||||||
if ([@"itemCount" isEqualToString:name]) {
|
if ([@"itemCount" isEqualToString:name]) {
|
||||||
self.itemCount = [prop unsignedIntegerValue];
|
self.itemCount = [prop unsignedIntegerValue];
|
||||||
[self.view reloadData];
|
[self.view reloadData];
|
||||||
} else if ([@"renderPage" isEqualToString:name]) {
|
} else if ([@"renderItem" isEqualToString:name]) {
|
||||||
[self.itemViewIds removeAllObjects];
|
[self.itemViewIds removeAllObjects];
|
||||||
[self clearSubModel];
|
[self clearSubModel];
|
||||||
[self.view reloadData];
|
[self.view reloadData];
|
||||||
@ -138,5 +139,50 @@ - (void)blendSubNode:(NSDictionary *)subModel {
|
|||||||
}];
|
}];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
- (void)callItem:(NSUInteger)position size:(CGSize)size {
|
||||||
|
NSValue *old = self.itemSizeInfo[@(position)];
|
||||||
|
if (old && CGSizeEqualToSize([old CGSizeValue], size)) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
self.itemSizeInfo[@(position)] = [NSValue valueWithCGSize:size];
|
||||||
|
NSIndexPath *indexPath = [NSIndexPath indexPathForRow:position inSection:0];
|
||||||
|
[UIView performWithoutAnimation:^{
|
||||||
|
[self.view reloadItemsAtIndexPaths:@[indexPath]];
|
||||||
|
}];
|
||||||
|
}
|
||||||
|
|
||||||
|
- (NSInteger)collectionView:(UICollectionView *)collectionView numberOfItemsInSection:(NSInteger)section {
|
||||||
|
return self.itemCount;
|
||||||
|
}
|
||||||
|
|
||||||
|
- (__kindof UICollectionViewCell *)collectionView:(UICollectionView *)collectionView cellForItemAtIndexPath:(NSIndexPath *)indexPath {
|
||||||
|
NSUInteger position = (NSUInteger) indexPath.row;
|
||||||
|
NSDictionary *model = [self itemModelAt:position];
|
||||||
|
NSDictionary *props = model[@"props"];
|
||||||
|
DoricCollectionViewCell *cell = [collectionView dequeueReusableCellWithReuseIdentifier:@"doricCell" forIndexPath:indexPath];
|
||||||
|
if (!cell.viewNode) {
|
||||||
|
DoricCollectionItemNode *itemNode = [[DoricCollectionItemNode alloc] initWithContext:self.doricContext];
|
||||||
|
[itemNode initWithSuperNode:self];
|
||||||
|
cell.viewNode = itemNode;
|
||||||
|
[cell.contentView addSubview:itemNode.view];
|
||||||
|
}
|
||||||
|
DoricCollectionItemNode *node = cell.viewNode;
|
||||||
|
node.viewId = model[@"id"];
|
||||||
|
[node blend:props];
|
||||||
|
CGSize size = [node.view measureSize:CGSizeMake(collectionView.width, collectionView.height)];
|
||||||
|
[node.view layoutSelf:size];
|
||||||
|
[self callItem:position size:size];
|
||||||
|
return cell;
|
||||||
|
}
|
||||||
|
|
||||||
|
- (CGSize)collectionView:(UICollectionView *)collectionView layout:(UICollectionViewLayout *)collectionViewLayout sizeForItemAtIndexPath:(NSIndexPath *)indexPath {
|
||||||
|
NSUInteger position = (NSUInteger) indexPath.row;
|
||||||
|
NSValue *value = self.itemSizeInfo[@(position)];
|
||||||
|
if (value) {
|
||||||
|
return [value CGSizeValue];
|
||||||
|
} else {
|
||||||
|
return CGSizeMake(100, 100);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
@end
|
@end
|
@ -14,7 +14,8 @@
|
|||||||
* limitations under the License.
|
* limitations under the License.
|
||||||
*/
|
*/
|
||||||
import { Stack } from './layouts'
|
import { Stack } from './layouts'
|
||||||
import { Property, IView, Superview } from '../ui/view'
|
import { Property, IView, Superview, View } from '../ui/view'
|
||||||
|
import { layoutConfig } from '../util/index.util'
|
||||||
|
|
||||||
export class CollectionItem extends Stack {
|
export class CollectionItem extends Stack {
|
||||||
/**
|
/**
|
||||||
@ -77,3 +78,17 @@ export class Collection extends Superview implements ICollection {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
export function collection(config: ICollection) {
|
||||||
|
const ret = new Collection
|
||||||
|
for (let key in config) {
|
||||||
|
Reflect.set(ret, key, Reflect.get(config, key, config), ret)
|
||||||
|
}
|
||||||
|
return ret
|
||||||
|
}
|
||||||
|
|
||||||
|
export function collectionItem(item: View) {
|
||||||
|
return (new CollectionItem).also((it) => {
|
||||||
|
it.layoutConfig = layoutConfig().wrap()
|
||||||
|
it.addChild(item)
|
||||||
|
})
|
||||||
|
}
|
||||||
|
Reference in New Issue
Block a user